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5 生 站 本 硬 古 和 是 到 


> 工作 应 用 速 查 : 本 书 实例 全 面 、 系 统 ， 涉 及 程序 开发 的 各 个 方面 ,适合 各 级 程序 开发 人 员 速 查 速 用 。 


> 项 目 开发 参考 : 程序 员 借助 本 书 提供 的 实例 源 代码 ， 可 以 快速 搭建 工程 项 目 ， 提 
> 学 习 实战 练习 : 入 门 者 的 实战 训练 大 人 全， 不 但 可 以 激发 学 习 兴趣 ， 更 可 提 


开发 效率 . 
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编程 实战 能 力 和 编程 思维 水 平 。 
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内 容 简 介 


《PHP 开发 实例 大 全 〈 基 础 卷 ) 》 短 选 、 汇 集 了 PHP 开发 从 基础 知识 到 高 级 应 用 各 个 层面 的 大 量 实例 及 源 代码 ， 
共有 600 个 左右 ， 每 个 实例 及 源 代码 按 实例 说 明 、 关 键 技术 、 设 计 过 程 、 详 尽 注释 、 秘 笈 心 法 的 顺序 进行 了 分 析 解读 。 
全 书 分 5 篇 15 章 ， 共 约 600 个 实例 ， 内 容 有 : 开发 环境 、PHP 基础 、Web 页 面 交互 、 文 件 操作 、 会 话 应 用 、 图 形 图 像 
处 理 、 面 向 对 象 、MySQL 数据 库 与 PHP、MySQL 高 级 应 用 技术 、PHP 操作 SQL Server 数据 库 、PHP 操作 Access 数据 
库 、PHP 操作 Oracle 数据 库 、ADODB 类 库 、Smarty 模板 、 综 合 应 用 。 配 书 光盘 附带 了 实例 的 源 程序 和 部 分 讲解 视频 。 

《PHP 开发 实例 大 全 基础 卷 )》 既 适合 PHP 程序 员 参 考 和 查阅 ， 也 适合 PHP 初学 者 ， 如 高 校 学 生 、 软 件 开发 培 
训 学 员 及 相关 求职 人 员 学 习 、 练 习 、 速 查 使 用 。 


本 书 封面 贴 有 清华 大 学 出 版 社 防伪 标签 ， 无 标签 者 不 得 销售 。 
版 权 所 有 ， 侵 权 必 究 。 侵 权 举 报 电话 : 010-62782989 13701121933 
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特别 说 明 : 
《PHP 开发 实例 大 全 》 分 为 基础 卷 〈 即 本 书 ) 和 提高 卷 两 册 。 本 书 的 前 身 是 《PHP 开发 实战 1200 例 〈 第 
I 卷 ) 》。 


编写 目的 


1. 方便 程序 员 查阅 


程序 开发 是 一 项 艰辛 的 工作 ， 挑 灯 夜 战 、 加 班 加 点 是 常 有 的 事 。 在 开发 过 程 中 ， 一 个 技术 问题 可 能 会 占用 几 
天 甚至 更 长 时 间 。 如 果 有 一 本 开发 实例 大 全 可 供 翻阅 ， 从 中 找到 相似 的 实例 作 参考 ， 也 许 几 分 钟 就 可 以 解决 问题 。 
本 书 编写 的 主要 目的 就 是 方便 程序 员 查 阅 、 提 高 开发 效率 。 


2. 通过 分 析 大 量 源 代 码 ， 达 到 快速 学 习 之 目的 


本 书 提供 了 约 600 个 开发 实例 及 源 代码 ， 附 有 相应 的 注释 、 实 例 说明 、 关 键 技术 、 设 计 过 程 和 秘笈 心 法 ， 对 
实例 中 的 源 代码 进行 了 比较 透彻 的 解析 。 相 信 这 种 办 法 对 激发 学 习 兴 趣 、 提 高 学 习 效率 极 有 帮助 。 


3. 通过 阅读 大 量 源 代码 ， 达 到 提高 熟练 度 之 目的 


俗话 说 “ 熟 能 生 巧 ”， 读 者 只 有 通过 阅读 、 分 析 大 量 源 代码 ， 并 亲自 动手 去 做 ， 才 能 够 深刻 理解 、 运 用 自如 ， 
进而 提高 编程 熟练 度 ， 适 应 工作 之 需要 。 


4. 实例 源 程序 可 以 “ 拿 来 ”就 用 ， 提 高 了 效率 


本 书 的 很 多 实例 ， 可 以 根据 实际 应 用 需求 稍 加 改动 ， 拿 来 就 用 ， 不 必 再 去 从 头 编写 ， 从 而 节约 时 间 ， 提 高 工 
作 效 率 。 


本 书 内 容 


全 书 分 5 篇 15 章 ， 共 约 600 个 实例 ， 内 容 有 : 开发 环境 、PHP 基础 、Web 页 面 交互 、 文 件 操作 、 会 话 应 用 、 
图 形 图 像 处 理 、 面 向 对 象 、MySQL 数据 库 与 PHP、MySQL 高 级 应 用 技术 、PHP 操作 SQL Server 数据 库 、PHP 
操作 Access 数据 库 、PHP 操作 Oracle 数据 库 、ADODB 类 库 、Smarty 模板 、 综 合 应 用 。 书 中 所 选 实例 均 来 源 于 
一 线 开 发 人 员 的 实际 项 目 开发 ， 襄 括 了 开发 中 经 常 遇 到 和 需要 解决 的 热点 、 难 点 问题 ， 使 读者 可 以 快速 地 解决 开发 
中 的 难题 ， 提 高 编程 效率 。 本 书 知识 结构 如 下 图 所 示 。 

本 书 在 讲解 实例 时 采用 统一 的 编排 样式 ， 多 数 实例 由 “实例 说 明 ”“ 关 键 技术 ” “设计 过 程 ”“ 秘 笈 心 法 ” 
4 部 分 构成 。 其 中 ，“ 实 例 说 明 ” 部 分 采用 图 文 结合 的 方式 介绍 实例 的 功能 和 运行 效果 “关键 技术 ”部 分 介 
绍 了 实例 使 用 的 重点 、 难 点 技术 ; “设计 过 程 ”部 分 讲解 了 实例 的 详细 开发 过 程 ， “秘笈 心 法 ”部 分 给 出 了 与 
实例 相关 的 技巧 和 经 验 总 结 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


亮点 内 容 导航 
第 1 篇 基础 篇 (222 个 实例 )|| | 第 2 篇 ”常用 技术 篇 (124 个 实例 ) ||| 第 3 篇 ”数据库 篇 (191 个 实例 ) 
坟 I I I 于 I 到 I ] [ I I I ] 
加 语 | [3 Sileneale 豆 
w 应 图 时 语 
和 | | 反 || 星 || 可 | 革 | 对 | | 于 || 咒 | | 估 || 可 数 | | 作 | | 句 || 作 | | 作 || 作 
配 | | 号 | | || 数 | | 日 || 十 处 之 wm|| > 
置 || 写 | | 开 | | ~ | 期 || 和 下 加 | | 又 名 
引 | 估 | 朗 | 六 || 血 | | 名 ;| 
前 工 | | 组 | | 各 || 筷 砸 || 总 委 | | 数 || 数 
开 | | 化 | | 中 | | 的 | | 处 || 号 数 吾 | | 据 | | 据 
发 | | 安 应 | | 理 | | 页 指 数 | | 库 || 库 
环 | | 赣 用 | | 技 || 而 库 据 
境 | | 包 术 || 交 库 
互 
| 
第 4 篇 新 技术 篇 (44 个 实例 ) 第 5 篇 综合 应 用 篇 (44 个 实例 ) 
I I 
上 加 如 | [如 | 说 | [ 郊 ]| 站 | 网 [和 | [后 
站 || 册 | | 据 | | 内 | | 物 || 书 | | 台 
加 号 页 | | 公 || “| | 输 | | 搜 | | 车 || 订 | | 管 
模 面 | | 共 || 登 | | 出 | | 过 单 | | 理 
类 板 编 | | 文 || 录 处 | | 系 
库 码 | | 御 理 | | 统 
设 人 
计 录 


本 书 特点 


1. 实例 极为 丰富 


本 书 精 选 了 约 600 个 实例 ， 另 外 一 册 《PHP 开发 实例 大 全 〈 提 高 卷 ) 》 也 精 选 了 提高 部 分 约 600 个 实例 ， 
这 样 ， 两 册 图 书 总 计 约 1200 个 实例 ， 可 以 说 是 目前 市 场 上 实例 最 多 、 知 识 点 最 全 面 、 内 容 最 丰富 的 软件 开发 类 
图 书 ， 涵 盖 了 编程 中 各 个 方面 的 应 用 。 


2. 程序 解释 详尽 


本 书 提供 的 实例 及 源 代码 ， 附 有 相应 的 注释 、 实 例 说 明 、 关 键 技术 、 设 计 过 程 和 秘笈 心 法 。 分 析 解 释 详尽 
便于 快速 学 习 。 


3. 实践 实战 性 强 

本 书 的 实例 及 源 代 码 很 多 来 自 现实 开发 中 ， 光 盘 中 绝 大 多 数 实例 给 出 了 全 部 源 代 码 ， 读 者 可 以 直接 调用 、 研 
读 、 练 习 。 
关于 光盘 

1. 实例 学 习 注 意 事 项 


读者 在 按照 本 书 学 习 、 练 习 的 过 程 中 ， 可 以 从 光盘 中 复制 源 代码 ， 修 改 时 注意 去 掉 源码 文件 的 只 读 属性 。 
有 些 实例 需要 使 用 相应 的 数据 库 或 第 三 方 资源 ， 在 使 用 前 需要 进行 相应 配置 ， 具 体 步骤 请 参考 书 中 或 者 光盘 中 
的 配置 说 明 。 


前 


叫 


2. 实例 源 代码 及 视频 位 置 


本 书 光盘 提供 了 实例 的 源 代码 ， 位 置 在 光盘 中 的 “MR\ 章 号 \ 实 例 序 号 ”文件 夹 下， 例如 ，“MR\04\226” 表 示 
实例 226， 位 于 第 4 章 。 部 分 实例 提供 的 视频 讲解 ， 也 可 根据 以 上 方式 查找 。 由 于 有 些 实 例 源 代码 较 长 ， 限 于 篇 
幅 ， 图 书 中 只 给 出 了 关键 代码 ， 完 整 代码 放置 在 光盘 中 。 


3. 视频 使 用 说 明 
本 书 提供 了 部 分 实例 的 视频 讲解 ， 在 目录 中 标题 前 边 有 视频 图 标的 实例 ， 即 表示 在 光盘 中 有 视频 讲解 。 视 
频 采用 EXE 文件 格式 ， 无 须 使 用 播放 器 ， 双 击 就 可 以 直接 播放 。 
读者 对 象 
PHP 程序 员 ，PHP 初学 者 ， 如 高 校 大 学 生 、 求 职 人 员 、 培 训 机 构 学 员 等 。 
本 书 服务 


如 果 您 使 用 本 书 的 过 程 中 遇 到 问题 ， 可 以 通过 如 下 方式 与 我 们 联系 。 
服务 QQ: 4006751066 
服务 网 站 : http://www.mingribook.com 


本 书 作者 


本 书 由 软件 开发 技术 联盟 组 织 编写 ， 参 与 编写 的 程序 员 有 赛 硅 春 、 王 小 科 、 王 国 辉 、 王 占 龙 、 高 春 艳 、 张 
闭 、 杨 丽 、 辛 洪 郁 、 周 佳 星 、 申 小 琦 、 张 宝 华 、 葛 忠 月 、 王 雪 、 李 贺 、 吕 艳 妃 、 王 喜平 、 张 领 、 杨 贵 发 、 李 根 
福 、 刘 志 铭 、 宋 禹 蒙 、 刘 丽 艳 、 刘 莉莉 、 王 雨 竹 、 刘 红 艳 、 隋 光宇 、 郭 闭 、 崔 佳音 、 张 金辉 、 王 敬 洁 、 宋 晶 、 
刘 佳 、 陈 英 、 张 磊 、 张 世 辉 、 高 茹 、 陈 威 、 张 彦 国 、 高 飞 、 李 严 。 在 此 一 并 致谢 ! 


第 1 章 开发 环境 .… 

1.1 AppServ 一 一 PHP 集成 化 安装 包 .. 
名 中 实例 001 通过 AppServ 配置 PHP 开发 环境 
鳃 和 实例 002 AppServ 应 用 技巧 
名 和 实例 003 第 1 个 PHP 程序 

1.2 XAMPP 一 一 PHP 集成 化 安装 包 .. 

实例 004 通过 XAMPP 配置 PHP 开发 环境 
实例 005 测试 XAMPP 是 否 安装 成 功 
实例 006 XAMPP 应 用 技巧 
实例 007 第 2 个 PHP 程序 
1.3 IIS+PHP+MySQL 一 一 独立 搭建 PHP 


实例 008 安装 PHP … 
实例 009 安装 MySQi 
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实例 011 第 3 个 PHP 程序 
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实例 019 第 5 个 PHP 程 序 … 
1.6 Dreamweaver 开发 工具 
实例 020 ”Dreamweaver 中 编码 格式 的 选择 .… 
实例 021 Dreamweaver 中 创建 表格 


第 2 章 PHP 基础 


实例 022 在 表格 中 插入 宠物 照片 …… 
实例 023 ”Dreamweaver 中 创建 表单 .… 
实例 024 ”Dreamweaver 中 创建 和 附加 CSS 样式 
实例 025 Dreamweaver 控制 弹出 信息 .………… 
实例 026 ”Dreamweaver 控制 浏览 器 的 窗口 
实例 027 通过 Dreamweaver 创建 站 点 ….… 
实例 028 ”通过 Dreamweaver 开发 第 1 个 PHP 


1.7 Zend Studio 开发 工具 
实例 029 安装 Zend Studio..… 
实例 030 Zend Studio 创建 PHP 项 目 … 
实例 031 Zend Studio 编码 格式 的 转换 . 
实例 032 Zend Studio 中 快捷 键 的 运用 . 

鳃 和 实例 033 ”Zend studio 中 部 署 Apache 服务 器 


2.1 基本 语法 …. 
实例 034 在 页 面 中 打印 PHP 的 配置 信息 . 
实例 035 在 页 面 中 打印 服务 器 时 间 
实例 036 在 页 面 中 打印 当前 执行 的 PHP 文件 名 
实例 037 区 分 单 引号 和 双 引 号 …………………… 
实例 038 ”动态 输出 JavaScript 代码 
实例 039” 当 数字 遇 到 了 字符 串 .…. . 
实例 040 ”PHP 程序 员 的 基础 一 一 变量 的 应 用 ………72 
实例 041 打印 系统 环境 变量 信息 print r($_ENV) …73 

实例 042 ”使 用 可 变 变 量 输出 “ILike PHP!” 

实例 043 ”使 用 转 义 字符 输出 特殊 字符 

实例 044 ”使 用 常量 指定 PI 的 值 计 算 圆 的 面 


实例 045 自 定义 数字 的 加 密 /解密 算法 . 
实例 046 ”比较 两 个 时 间 戳 的 大 小 
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实例 048 
实例 049 
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1.1 AppServ 一 一 PHP 集成 化 安装 包 


AppServ 将 Apache、PHP、MySQL 和 phpMyAdmin 等 服务 器 软件 和 工具 安装 配置 完成 后 进行 打包 处 理 ， 开 
发 人 员 只 要 到 网 站 上 下 载 该 软件 然后 安装 ， 即 可 完成 PHP 开发 环境 的 快速 搭建 ， 非 常 适合 初学 者 使 用 。 


> E 
初级 | 
实体 
实例 001 趣味 指数 : oboloioll 

图 实例 说 明 
在 本 实例 中 ， 讲 解 如 何 通过 AppServ 配置 PHP 的 开发 环境 ， 配 置 完成 后 将 出 现 如 图 1.1 所 示 对 话 框 。 
AppSerr 2.5.10 seue ‘=151x| 
Completing the AppServ 25 10 
Setup Wizard 
有 urrahbdooatiawead 
上 区 Eeepsee 
E W SartsQL 
[未 
口号 
oO: 
a 
EE [Be ] co 
图 1.1 通过 AppServ 配置 PHP 开发 环境 
图 关键 技术 


通过 AppServ 配置 PHP 开发 环境 时 ， 首 先 从 互联 网 上 下 载 AppServ 的 安装 文件 ， 下 载 地 址 为 
http://www.AppServnetwork.com/。 


< 注意 : 在 使 用 AppServ 搭建 PHP 开发 环境 时 ， 必 须 确保 在 系统 中 没有 安装 Apache、PHP 和 MySQL， 否 则 
要 先 将 这 些 软件 却 载 ， 然 后 应 用 AppServ。 


在 软件 的 安装 过 程 中 ， 要 重点 注意 下 面 几 个 步骤 
设置 安装 路 径 。 

选择 安装 软件 。 

设置 端口 号 。 

设置 数据 库 密码 。 

设置 数据 库 编码 格式 。 


图 设计 过 程 
下 面 对 应 用 AppServ 集成 化 安装 包 搭建 PHP 开发 环境 的 具体 操作 步骤 进行 讲解 。 


(1) 双击 AppServ-win32-2.5.10.exe 文件 ， 打 开 如 图 1.2 所 示 的 AppServ 启动 对 话 框 。 
(2) 单 击 图 1.2 中 的 Next 按钮 ， 进 入 如 图 1.3 所 示 的 AppServ 安装 协议 对 话 框 。 


图 网 轿 罗 加 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


Welcome to the AppServ 25 10 
Setup Wizard 


Tis wirerd wil guide you troush the nstelotien ofhopaerv 
Zs 


Tis reconmended thrat yo dose al other apoicasens 


图 1.2 AppServ 启动 页 面 图 1.3 AppServ 安装 协议 


(3) 单 击 I Agree 按钮 ， 进 入 如 图 1.4 所 示 的 对 话 框 ， 在 其 中 设置 AppServ 的 安装 路 径 〈 默 认 安 装 路 径 一 
般 为 CAppServ) ，AppServ 安装 完成 后 ，Apache、MySQL、PHP 都 将 以 子 目录 的 形式 存储 到 该 目录 下 。 
(4) 单 击 Next 按钮 ， 进 入 如 图 1.5 所 示 的 对 话 框 ， 在 其 中 选择 要 安装 的 程序 和 组 件 〈 默 认为 全 选 ) 。 


Select Components 
Seiect the components you Went soinatal, cear the compenents 
youdo rotwant io nstal, 


a 


可 


图 1.4 AppServ 安装 路 径 选择 图 1.5 AppServ 安装 选项 


_.GBg 技巧 : 在 第 (4) 步 中 ， 如 果 本 机 已 经 安装 MySQL 数据 库 ， 那 么 可 以 不 选中 MySQL Database 复 选 框 ， 仍 
使 用 本 机 已 经 存在 的 MySQL 数据 库 。 

(5) 单 击 图 1.5 中 的 Next 按钮 ， 进 入 如 图 1.6 所 示 的 对 话 框 ， 在 其 中 填写 计算 机 名 称 、 添 加 邮箱 地 址 、 设 

置 Apache 的 端口 号 (默认 为 80 端口 ) 。 


tp 
Acache HTTP Server riomation 
Pease eter you servers nomator 


1.6 ”Apache 端口 号 设置 
< 注意 : Apache 服务 器 端口 号 的 设置 ， 直 接 关系 到 Apache 服务 器 是 否 能 够 正常 启动 。 如 果 本 机 中 的 80 端口 


被 IIS 或 者 迅雷 占用 ， 那 么 这 里 就 需要 修改 Apache 的 端口 号 ， 或 者 修改 IIS 和 迅雷 的 端口 号 ， 这 样 
才能 完成 Apache 服务 器 的 配置 。 如 果 出 现 端口 冲突 ， 那 么 将 导致 安装 失败 ，Apache 服务 不 能 启动 。 
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(6) 单 击 Next 按钮 ， 进 入 如 图 1.7 所 示 的 对 话 框 ， 在 其 中 设置 MySQL 数据 库 root 用 户 的 登录 密码 及 字符 集 。 


[ED 说 明 : MySQL 数据 库 的 字符 集 ， 可 以 设置 为 UTF-8、GBK 或 者 GB2312 格式 。 这 里 将 字符 集 设置 为 GB2312 
Simplified Chinese， 表 示 MySQL 数据 库 的 字符 集 将 采用 简体 中 文 形式 。 


Er 


SN MSQL Server Contguraton 
Corfere he MySQL sever matonee, 


MySQL 
Pease erter Reotpesererd to Mysa see 
Ee rotpeseers 
一 2 
ss | 


| 
图 1.7 设置 MySQL 数据 库 root 用 户 的 密码 和 字符 集 


GBS 技巧: 对 于 在 图 1.7 中 设置 的 MySQL 数据 库 root 用 户 的 密码 必须 牢记 ， 因 为 程序 在 连接 数据 库 时 必须 使 
用 这 个 密码 。 建 议 读者 将 这 个 密码 设置 为 111, 因为 这 是 在 开发 本 书 中 的 程序 时 所 使 用 的 数据 库 密 码 。 
如 此 ， 在 运行 本 书 中 的 数据 库 程 序 时 ， 就 不 需要 修改 密码 ， 否 则 要 修改 连接 数据 库 的 密码 。 如 果 忘 
记 安 装 时 设置 的 密码 ， 最 直接 有 效 的 解决 方式 是 重新 安装 AppServ。 
(7) 单 击 Install 按钮 开始 安装 ， 如 图 1.8 所 示 。 
(8) 安装 完成 后 可 以 在 开始 菜单 的 AppServ 相关 操作 列表 中 启动 Apache 及 MySQL 服务 ， 如 图 1.9 所 示 。 


Completing the AppServ 2.5.10 
izard 


p 
户 | ing 
ER WW startMysQL 
上 妹 
有 

SS 
BN 

Meat neal sysien yin Ee 
ee [em ] ce 
图 1.8 AppServ 安装 页 面 1.9 AppServ 安装 完成 页 面 


国 秘笈 心 法 


心 法 领悟 001: Apache 的 配置 文件 。 
Apache 的 配置 文件 存储 于 C:\AppServ\Apache2.2\conf\httpd.conf。 通过 Apache 配置 文件 可 以 设置 Apache 的 
端口 号 、Apache 服务 器 的 根 目 录 或 者 控制 Apache 是 否 支 持 伪 静态 。 
(1) 设置 Apache 的 端口 号 : 


Listen 80 


(2) 设置 Apache 服务 器 的 根 目录 : 


DocumentRoot "C:/AppServ/www" 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
(3) 设置 对 伪 静 态 的 支持 : 
机 oadModule rewrite_module modules/mod rewrite.so 
将 该 项 前 面 的 “#” 去 掉 ， 可 启动 该 项 。 查 找 httpd.conf 文件 ， 找 到 其 中 的 AllowOverride 项 ,将 其 值 都 修改 
为 All。 
完成 对 Apache 的 修改 后 ， 必 须 保存 文件 ， 并 重新 启动 Apache 服务 器 才能 够 生效 。 
中 级 


ey 
| 
实例 002 地 呆 指 数 : 友 刘 克 


力 实例 说 明 
安装 AppServ 后 ， 可 以 对 其 进行 测试 。 在 正 浏览 器 的 地 址 栏 中 输入 hppt/127.0.0.1， 如 果 输 出 如 图 1.10 所 
示 的 页 面 ， 则 说 明 PHP 开发 环境 配置 成 功 。 


文件 归 镜 笛 于 查看 中 和 工具 四 一 帮 动 咱 
ER 


The AppServ Open Project - 2.5.10 for Windows 


误 phpMyAdmin Database Manaqer Version 2.10.3 
划 PHP Information Version 5.2.6 


10 0r 
AppSev is a merging opan source sowere installer packace fcr Windows 
incudos， 


» Apache Web Server Version2.28 

» PHP Script Language Velson 5.2.6 

» MySQL Database Version5.0.51b 

» phpMyAdmin Datebase Manegor Vorcion 2.10.3 


图 1.10 PHP 开发 环境 配置 成 功 


图 关键 技术 


AppServ 安装 完成 后 ， 整 个 目录 默认 安装 在 C:\AppServ 下 ， 此 目录 下 包含 4 个 子 目录 ， 如 图 1.11 所 示 ， 用 
户 可 以 将 所 有 程序 文件 存储 到 www 目录 下 。 


忌 

图 加 Mpache2.2 psche 的 存储 目录 

昌 自 Ws Mysql 的 存 绪 目录 

旬 昌 pho5 PIE 的 存储 路 径 

田 自 mw 网 页 文件 及 phpliyhdnin 的 存储 路 径 


1.11 AppServ 目录 结构 


在 Apache2.2\conf\ 目 录 下 ， 有 一 个 httpd.conf 文件 ， 它 是 Apache 服务 器 的 配置 文件 ， 在 这 个 文件 中 可 以 修 
改 Apache 服务 器 的 端口 号 、 根 目录 等 ， 所 有 有 关 Apache 服务 器 的 配置 都 在 这 个 文件 中 完成 。 

在 MySQL 目录 下 ， 有 一 个 my.ini 文件 ， 它 是 MySQL 服务 器 的 配置 文件 ， 存 储 MySQL 的 配置 信息 。 

在 MySQL\data 目录 下 存储 的 是 数据 库 文件 ， 所 有 程序 使 用 的 数据 库 都 存储 在 这 个 文件 夹 下 。 


[ED 说 明 : 如 果 MySQL 服务 器 的 版 本 是 5.1， 那 么 数据 库 文件 天 data 的 默认 存储 位 置 是 C:\Documents and 
Settings\All Users\Application Data MySQL\IMySQL Server 5.1\Data\。 


在 php5\ext 文件 夹 下 存储 的 是 PHP 内 置 的 函数 类 库 ， 以 .dll 的 格式 存储 ,而 PHP 的 配置 文件 php.ini 存储 在 
本 机 系统 盘 的 Windows 文件 夹 下 。 
www 目录 是 程序 运行 的 根 目 录 ， 也 就 是 说 我 们 要 运行 的 所 有 程序 都 必须 存储 在 这 个 目录 下 。phpMyAdmin 
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图 形 化 管理 工具 默认 存储 在 此 目录 下 。 
图 设计 过 程 
(1) www 文件 夹 存储 网 站 的 运行 文件 ， 其 默认 的 内 容 如 图 1.12 所 示 。 
ET ET | 站 
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图 1.12 www 文件 夹 的 默认 内 容 


(2) 其 中 ,index.php 是 默认 访问 127.0.0.1 时 浏览 的 内 容 ; 而 phpinfo.php 存储 的 是 PHP 的 配置 信息 和 支持 
的 模块 。phpinfo.php 的 内 容 如 图 1.13 所 示 。 


System 多 
Build Date |Nov 20 2009 17:20:57 

Compiler Isvc6 (Vsual C++ 6.0) 

Architecture bas 

Conngure Command |cscrpt Inclogo confgure 5 -enable-snapshotbuld 

Server APT |apache 20 Hander 

Virtual Directory Support |enabed 


1.13 phpinfo.php 的 内 容 
(3) 其 中 的 phpMyAdmin 文件 夹 存储 的 是 phpMyAdmin 图 形 化 管理 工具 。 
国 秘笈 心 ; 
心 法 领悟 002: AppServ 的 相关 说 明 。 
(1) 如 果 是 应 用 AppServ 配置 的 PHP 开发 环境 ， 那 么 在 IE 浏览 器 中 直接 输入 127.0.0.1 将 输出 如 图 1.10 
所 示 的 页 面 ， 因 为 在 www 文件 夹 下 有 一 个 默认 的 index.php 文件 ， 如 果 要 运行 www 文件 夹 下 的 其 他 文件 ， 那 
么 必须 在 127.0.0.1 后 指定 具体 的 文件 夹 或 者 文件 ， 例 如 ， 输 入 127.0.0.1/text.php 或 者 127.0.0.1/mr/。 
(2) Apache 的 启动 和 停止 。 
单 击 “ 开 始 ”按钮 ， 选 择 “ 程 序 ”/AppServ/Control Server by Service 命令 ， 在 弹出 的 菜单 中 完成 Apache、 
MySQL 服务 器 的 启动 和 停止 操作 。 
单 击 “ 开 始 ”按钮 ， 选 择 “ 设 置 ”/“ 控 制 面板 ”/“ 管 理工 具 ”/“ 服 务 ”命令 ,找到 Apache 2.2， 右 击 , 在 
弹出 的 快捷 菜单 中 完成 Apache 的 启动 、 停 止 或 者 重新 启动 操作 。 
完成 对 php.ini 文件 的 修改 后 ， 同 样 要 保存 文件 ， 重 新 启动 Apache 服务 器 后 ， 修 改 才 能 够 生效 。 


De 
一 初级 
实例 003 趣味 指数 : , 
国 实例 说 明 


AppServ 安装 、 调 试 成 功 后 ， 开 发 第 1 个 PHP 程序 ， 输 出 系统 的 当前 时 间 ， 运 行 结果 如 图 1.14 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


文 作品。 二 沁 中 ”查看 WD 中京 中 IROD ”| 鄞 | 


Enrol EE 
EE| 
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图 二 [| OT 4 
图 1.14 第 1 个 PHP 程 序 


图 关键 技术 
(1) 应 用 PHP 中 的 date0 函 数 ， 输 出 系统 的 当前 时 间 ， 设 置 时 间 的 格式 为 年 -月 -日 时 :分 : 秒 (Y-m-d H:i:s〉。 
(2) 将 编写 的 index.php 文件 存储 于 www 文件 夹 下 的 MR\01\003 目录 下 。 
在 运行 本 实例 时 , 会 发 现 程 序 输出 的 时 间 与 系统 的 当前 时 间 相 差 了 8 个 小 时 ，, 至 于 为 什么 会 出 现 此 种 情况 ， 
将 在 本 实例 的 秘笈 心 法 中 讲解 。 


图 设计 过 程 
(1) 通过 Dreamweaver 创建 一 个 index.php 脚本 文件 ， 存 储 于 MR/01/003/ 文 件 夹 下 。 
(2) 应 用 date0) 函 数 输出 系统 的 当前 时 间 ， 其 代码 如 下 : 


<2php 
echo date("Y-m-d H:i:s"); // 输 出 系统 的 当前 时 间 
> 
(3) 在 正 浏 览 器 的 地 址 栏 中 输入 http://127.0.0.1/mr/01/003/， 运 行 结果 如 图 1.14 所 示 。 
国 秘笈 心 法 


心 法 领悟 003: 对 于 系统 时 间 的 相关 说 明 。 

程序 输出 时 间 与 系统 当前 时 间 出 现 偏差 的 关键 是 php.ini 文件 的 设置 。 在 php.ini 文件 中 , 默认 设置 的 是 标准 
的 格林 威 治 时 间 ， 即 采用 的 是 英国 伦敦 时 间 ， 而 当地 时 间 是 北京 时 间 ， 所 以 会 出 现时 间 的 偏差 。 

PHP 的 配置 文件 存储 于 C:\Windows\php.ini 文件 中 。 在 php.ini 文件 中 ， 定 位 到 [date] 下 的 “:date.timezone =” 
选项 ， 去 掉 前 面 的 分 号 ， 并 设置 它 的 值 为 当地 所 在 时 区 使 用 的 时 间 ， 即 可 统一 程序 输出 的 时 间 与 系统 当前 
的 时 间 。 


:date timezone = 
例如 ， 如 果 当 地 所 在 时 区 为 东 作 区， 那么 就 可 以 设置 date.timezone 的 值 为 PRC、Asia/Hong_ Kong、Asia/ 
Shanghai (上 海 ) 或 者 Asia/Urumqi (乌鲁木齐 ) 等 ， 这 些 都 是 东 八 区 的 时 间 。 


1.2 XAMPP 一 一 PHP 集成 化 安装 包 


XAMPP (Apachet+MySQL+PHP+Perl) 是 一 个 功能 强大 的 建站 集成 软件 包 , 可 以 在 Windows、Linux、Solaris 
这 3 种 操作 系统 下 安装 使 用 ， 支 持 多 种 语言 ， 包 括 英文 、 简 体 中 文 、 繁 体 中文 、 韩 文 、 俄 文 、 日 文 等 。 


| 
实例 004 初级 


趣味 指数 : fd 


图 实例 说 明 
XAMPP 是 一 个 易于 安装 且 包含 MySQL、PHP 和 Perl 的 Apache 发 行 版 。 安 装 成 功 后 的 运行 效果 如 图 1.15 
所 示 。 
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图 1.15 XAMPP 安装 成 功 


图 关键 技术 


目前 XAMPP 的 Windows 版 本 是 1.7.3， 包 括 如 下 内 容 : 
Apache 2.2.14 (IPv6 enabled) 

MySQL 5.1.41 + PBXT engine 

PHP 5.3.1 

OpenSSL 0.9.81 

phpMyAdmin 3.2.4 

XAMPP Control Panel 2.5.8 

XAMPP CLI Bundle 1.6 

Webalizer 2.21-02 

Mercury Mail Transport System v4.72 
msmtp 1.4.19 

FileZilla FTP Server 0.9.33 

SQLite 2.8.17 

SQLite 3.6.20 

ADOdb 5.10 

eAccelerator 0.9.6-rcl 

Xdebug 2.0.6-dev 

Ming 0.4.3 

适用 于 Windows 2000/XP/2003/Vista/7。 

在 Windows 操作 系统 下 ，XAMPP 有 两 种 形式 : 
回 自 解压 RAR 包 一 一 简单 且 安全 

加 ”ZIP 压缩 包 一 一 XAMPP 的 普通 ZIP 压缩 档案 


国 设计 过 程 


国共 因 因 因 办 因 办 因 因 因 因 办 办 办 办 


加 


PHP 开发 实例 大 全 (基础 卷 ) 


XAMPP 1.7.3 版 的 具体 安装 步骤 如 下 : 
(1) 运行 .exe 安装 文件 ， 弹 出 如 图 1.16 所 示 对 话 框 ， 在 这 里 设置 XAMPP 的 安装 路 径 。 
(2) 安装 路 径 设 置 完成 后 ， 单 击 Install 按钮 ， 执 行 XAMPP 的 安装 ， 如 图 1.17 所 示 。 


而 XAMpp for wndows iE] 而 XAMPP for Windows [ef]| 


® Press Install button to start extraction 加 
。 Use Browse button to select tiration folder 
Xx from the folders tree. lt can bi red manually X 


Ifthe destination folde 
created automatically 


exist, it will be 
extraction 


。 After extraction, the setup script 


» To install semices or start/stop tI 
the XAMPP Control Panel 


| 习 
Dearaonfoaer 
全 | 


Instalation progress 


Destination folder 


Installation progress 
[ 


aa rea EE 
图 1.16 设置 XAMPP 的 安装 路 径 图 1.17 安装 XAMPP 


(3) XAMPP 安装 成 功 后 ， 将 弹出 如 图 1.18 所 示 的 操作 界面 ， 在 其 中 对 XAMPP 进行 设置 ， 包 括 是 否 创建 
桌面 快捷 方式 、 是 否 在 开机 时 启动 XAMPP 等 。 


着 


提 提 提 和 持 捍 持 提 提 和 持 捍 持 持 持 提 捍 捍 提 和 持 持 持 提 和 和 和 提 和 和 拉 持 和 拉 和 持 和 持 拉 拉 和 持 失 失 持 持 拉 提 持 持 提 拉 挂失 拉 和 和 


ight 2889 Carsten Wiednann 《P sD License) 
ten Wiednann <carsten_sttgtegnx -de 
ge lgesang 《kuoBapachefrien 


TT TT 


Control Panel 


图 1.18 设置 XAMPP 


至 此 ，XAMPP 安装 、 配 置 完 毕 。 
图 秘笈 心 法 
心 法 领悟 004: XAMPP 中 的 配置 文件 。 
XAMPP 中 各 种 配置 文件 的 存储 位 置 如 下 。 
Apache 基本 配置 : .\xampp\apache\conf\httpd.conf。 
Apache SSL: .\xampp\apache\conf\ssl.conf。 
Apache Perl 〈 仅 限 插件 ) : .\xampp\apache\conf\perl.conf。 
PHP: .\xampp\php\php.ini。 
MySQL: .\xampp\mysql\bin\my.ini。 
phpMyAdmin: .\xampp\phpMyAdmin\config.inc.php。 


因 办 办 办 办 办 
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FileZilla FIP 服务 器 : \xampp\FileZillaFTP\FileZilla。 


初级 
趣味 指数 : 请 博 去 家 


实例 005 


力 实例 说 明 


成 功 安装 XAMPP 后 ， 启 动 Apache 服务 器 ， 在 浏览 器 的 地 址 栏 中 输入 http://localhost 或 http://127.0.0.1， 
即 可 检测 所 有 的 XAMPP 样 例 和 工具 ， 运 行 结果 如 图 1.19 所 示 。 


图 1.19 检测 安装 是 否 成 功 
图 关键 技术 


XAMPP 中 默认 将 所 有 网 络 文档 存储 于 htdocs 主 文件 夹 中 〈.\xampp\htdocs) 。 默 认 htdocs 主 文件 夹 下 的 内 
容 如 图 1.20 所 示 。 


ET ET 
WE [DO (wpe stds: EE 
[Em 7 1 [ss 7 | 


图 1.20 XAMPP 的 默认 网 络 文件 
读者 可 以 在 浏览 器 的 地 址 栏 中 输入 http://localhost/ 来 检测 XAMPP 是 否 安装 成 功 。 
力 设计 过 程 


(1) XAMPP 文件 夹 存储 的 是 XAMPP 的 各 种 配置 信息 , 当 直 接 运 行 index.php 文件 时 ,调用 的 就 是 XAMPP 
文件 夹 下 的 index.php 文件 ， 输 出 如 图 1.20 所 示 的 内 容 。 


(2) 在 index.html 文件 中 ， 输 出 一 个 简单 的 测试 信息 ， 如 图 1.21 所 示 。 


外 
让 WW 于 ws/ on Vics tw 可 加 RSS 


It works! 引 
BE [| Oa 


加 


PHP 开发 实例 大 全 (基础 卷 ) 
图 1.21 通过 HTML 测试 PHP 是 否 安装 成 功 
(3) 在 index.php 文件 中 , 通过 header0 函 数 跳 转 到 xampp 文件 夹 下 的 index.php 文件 , 输出 XAMPP 的 信息 。 


心 法 领悟 005: 启动 、 停 止 和 测试 XAMPP。 
通过 文件 xampp\xampp-control.exe 控制 XAMPP 的 启动 、 停 止 和 测试 。 


力 实例 说 明 
XAMPP 只 为 开发 者 服务 , 切记 不 要 将 其 应 用 于 生产 环境 ,因为 对 于 生产 环境 而 言 , 使 用 XAMPP 可 能 会 带 
来 灾难 性 的 打击 。 
因为 MySQL 管理 员 (root) 未 设置 密码 ， 用 户 可 以 直接 通过 phpMyAdmin 访问 MySQL 服务 器 ， 修 改 数据 
库 中 的 数据 ， 或 者 通过 网 络 访问 ， 运 行 结果 如 图 1.22 所 示 。 
ETIIIEITIITTTTIPTTTTEEZEDECOOOOS 


文件 四 ”编辑 EE) 查看 W) 收 豪 4) 工具) 而 | 3 
矶 本 WW [ 轩 htts /1127 0 0 Uphpeysinin/index php7ab=cdcolttoken-os02bce dud2 7] 区 和 到 | 访 按 | 


全 图 加 


数据 库 
phpmyadmin 加 了 


phpmyadmin (8) F bookmark 办 同 缮 而 Xs 
Ee PE il 


[TT [| (Ons 四 


1.22 直接 访问 MySQL 数据 库 


图 关键 技术 


要 确保 MySQL 数据 库 的 安全 ， 必 须 为 MySQL 管理 员 (root) 设置 密码 ， 其 方法 如 下 : 
以 root 用 户 的 身份 登录 phpMyAdmin， 在 phpMyAdmin 的 权限 中 设置 root 用 户 的 密码 。 操 作 界面 如 图 1.23 
所 示 。 


中 服务 器 : localhost 
_ 而 数据 话 “. 丸 SQL 间 状 态 ” 同 变 重 。[ 且 字符 集 “ 甩 引 学 、 全 权限 _ 忽 进 程 ”总 导出 防 导 入 
多 编辑 权限 : 用 户 roor'@'ocalhost 
广 售 改 室 妈 
7 天 
oes ep 
室 码 加 密 方式 。 G MySQL 4 1+ 

人 羔 客 MysQL40 


生成 室 码 E23| EE 一 | 


图 1.23 修改 MySQL 用 户 密码 
[| 说 明 : 更 改 root 的 密码 之 后 ， 还 要 修改 phpMyAdmin 中 的 相关 信息 ， 具 体 方法 请 参看 设计 过 程 。 


第 1 章 开发 环境 


图 设计 过 各 

在 phpMyAdmin 的 权限 中 完成 root 用 户 的 密码 设置 后 , 在 .xampp\phpmyadmin\ 下 搜索 config.inc.php 文件 ， 
定位 到 如 下 位 置 : 

/* Authentication type and info */ 

$cfg['Servers][$il['auth_type] = ‘http'; /设置 登录 方式 

$cfg['Servers'][$il[user] = root: /设置 用 户 名 

$cfe['Servers'][$il[password]= "111; /设置 密码 


Scfel'Servers'][Si][AllowNoPassword'] = true; 
设置 auth_type 的 值 为 “http”; 设置 password 的 值 为 “111”， 这 样 登录 phpMyAdmin 时 ， 就 必须 要 输入 
密码 ， 否 则 无 法 登录 。 


国 秘 稚 心 法 


心 法 领悟 006: 修改 MySQL 默认 字符 集 。 
修改 MySQL 默认 字符 集 为 utf8， 定 位 到 my.ini 文件 ， 需 添加 如 下 内 容 : 


[client] 
default_character set=utf8 
[mysqld] 

# default-character-set=utf8 
character-set-server = utf8 
collation-server = utf8_general_ci 
[mysql] 
default_character_set=utf8 


初级 
趣味 指数 : holed 
实例 说 明 


既然 XAMPP 只 为 开发 者 服务 ， 那 么 我 们 就 应 用 XAMPP 开发 一 个 PHP 程序 ， 熟 悉 一 下 XAMPP 的 应 用 。 
本 实例 简单 地 输出 一 段 文字 ， 其 运行 结果 如 图 1.24 所 示 。 


可 第 二 个 PiT 程 床 -Wiecrese EEC 
文件 四 ”编辑 E) 查看 W) 收藏 A) 工具 QD) 


奸 古 如 [站 http //127.0.0. 1/or/01/007/ 司 回 和 3 全 
现在 是 ，2010 年 06 月 28 日 05 时 24 分 31 秒 
局 大 [ 厂 [ [后 有 


Sl tels a 


图 1.24 第 2 个 PHP 程 序 


力 关键 技术 


(1) 确定 服务 器 的 运行 文件 夹 ， 编 写 PHP 脚本 文件 ， 将 其 存储 于 XAMPP 指定 的 运行 文件 夹 下 。 
(2) 应 用 PHP 的 date0 函 数 输出 系统 的 当前 时 间 ， 时 间 的 格式 是 “年 月 日 时 分 秒 ”。 


国 设计 过 程 
(1) 新 建 一 个 记事 本 文件 ， 编 写 PHP 脚本 ， 通 过 date0 函 数 输出 系统 的 当前 时 间 ， 其 代码 如 下 : 
a "date("Y 年 m 月 d 日 了 时 i 分 s 秘 "); 
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(2) 保存 这 个 记事 本 文件 ， 将 其 存储 于 xampp\htdocs\MR\01\007〈 这 是 笔者 在 本 机 中 定义 的 实例 存储 文 
件 夹 ) 。 


图 秘笈 心 法 

心 法 领悟 007: 配置 默认 的 开始 页 面 。 

如 果 在 浏览 器 地 址 栏 中 输入 http://localhost/xampp/, Apache 服务 器 会 自动 返回 一 个 默认 的 开始 页 面 , Apache 
会 自动 寻找 已 存在 的 类 似 index.php 的 索引 页 。httpd.conf 中 的 DirectoryIndex 指令 负责 这 个 功能 。 在 这 里 可 以 
定义 默认 开始 页 面 的 名 字 和 协议 。 


XAMPP 在 默认 状态 下 ，DirectoryIndex 指令 的 列表 如 下 : 
index php index php4 index:php3 index.cgi index.pl index.html indexhtm index htmlvarindex phtml 


1.3 IIS+PHP+MySQI 一 一 独立 搭建 PHP 开发 环境 


Intemet 信息 服务 器 即 Internet Information Server, 缩写 为 TS, 是 Microsoft 的 Web 服务 器 。 它 集成 于 Windows 
NT Server 之 中 ， 方 便 易 用 ， 为 Web 应 用 程序 提供 了 功能 强大 的 运行 平台 。 

本 书 使 用 IS 6.0， 在 Windows 2003 操作 系统 下 完成 PHP 环境 的 搭建 ， 所 使 用 的 软件 如 下 。 

加 ”PHP 软件 : php-5.3.1-nts-Win32-VC9-x86。 

加 ”MySQL 数据 库 : mysql-essential-5.1.39-win32.msi。 


| 说 明 : 上 述 版 本 是 笔者 所 使 用 的 ， 读 者 可 以 根据 自己 的 实际 情况 进行 调整 。 如 果 是 Windows 7 操作 系统 ， 
则 使 用 IS 7.0， 如 果 是 Windows XP 系统 ， 则 使 用 IIS 5.0。 


实例 008 趣味 指教 : 请 请 良家 | 


实例 说 明 


PHP 5.3.1 是 使 用 较 多 的 版 本 , 读者 可 以 到 PHP 的 官方 网 站 下 载 , 下 载 地 址 为 http://www.php.net/ downloads. php。 
本 实例 讲解 如 何 选择 、 安 装 PHP 5.3.1。 


力 关键 技术 


(1) 版 本 的 区 分 。PHP 推出 的 PHP 5.3.1 有 多 个 版 本 ， 包 括 VC6、X86 和 VC9、X86。 
回 VC 6: legacy Visual Studio 6 compiler， 是 使 用 此 编译 器 编译 的 。 
VC 9: the Visual Studio 2008 compiler， 是 用 微软 的 VS 编辑 器 编译 的 。 
(2) 版 本 的 选择 。 
如 果 在 Windows 下 使 用 Apache+PHP， 选 择 VC 6 版 本 ; 
如 果 在 Windows 下 使 用 IS+PHP， 选 择 VC 9 版 本 。 
(3) Non Thread Safe 和 Thread Safe。Non Thread Safe 是 非 线 程 安全 ;Thread Safe 是 线程 安全 。 官 方 不 建 
议 将 Non Thread Safe 应 用 于 生产 环境 ， 所 以 我 们 选择 Thread Safe 版 本 的 PHP。 


图 设计 过 程 
下 面 讲解 php-5.3.1-nts-Win32-VC9-x86 的 配置 方法 。 
(1) 将 下 载 的 文件 php-5.3.1-nts-Win32-VC9-x86.zip 解压 ， 重 新 命名 为 php， 并 将 其 复制 到 指定 的 目录 下 。 
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例如 C:\php、F:\php 等 。 这 里 将 php 放置 在 F:\PkhiisPHP 目录 下 。 

(2) 将 F:\PkhiisPHP\php 目录 下 的 libMySQL.dll 文件 复制 到 C:\Windows\system32\( 如 果 是 Windows 2000， 
则 为 CA\WINNT\system32\) 目录 下 。 

(3) 将 F:\PkhiisPHP\php 目录 下 的 php.ini-development 重 命名 为 php.ini， 如 图 1.25 所 示 ， 并 将 其 复制 到 系 
统 盘 的 Windows 文件 夹 下 〈 例 如 ， 若 C 盘 为 系统 盘 ， 则 是 C:\Windows) 。 


EP 
名 恨 -间作 | 站 扫 案 己 XH | 加- 
地 址 ) | 咏 nT IEEIE 


文件 和 文件 卖 任务 php.gf 3X5 GF 图 人 
本 ni 9 KS 配置 设置 
em | re 3 是 本 
php<gee 9S 应 用 程序 
合格 寺 择 的 项 目 发 布 到 配 womee Ja 应 用 程序 下 
@ ed EN puns-phosco.reg 1K8 注册 表 项 > 
所 项目 zl a "i 


辽 定 2 个 对 象 人 


图 1.25 生成 php.ini 


(4) 打开 php.ini 文件 并 定位 到 extension_dir="./" 这 一 行 ， 修 改 为 extension_dir=" F:\PkhiisPHP\php\ext"。 
(5) 同样 在 php.ini 文件 中 ， 将 下 面 5 项 设置 前 的 分 号 去 掉 ， 并 设置 相应 的 参数 ， 完 成 对 CGI 和 FastCGI 


et 

:cgirfe2616_headers = 1 

(6) 加 载 动态 库 。 例 如 ， 定 位 到 :extension=php_MySQL.dll 这 一 行 ， 将 前 面 的 分 号 “:” 去 掉 ， 完 成 MySQL 
动态 库 的 加 载 。 

(7) PHP 安装 成 功 后 ， 还 要 对 FastCGI 进行 配置 ， 在 系统 盘 的 \system32\inetsrv\ 文 件 夹 下 找到 fcgiext.ini 文 
件 ， 在 该 文件 的 最 后 添加 如 下 内 容 : 


[Types] 

Php=PHP 

[PHP] 
ExePath=F:\PkhiisPHP\php\php-cgi.exe 


其 中 ，[Types] 指 定语 言 为 PHP; [PHP] 指 定 php-cgi.exe 在 本 机 中 的 安装 位 置 。 
国 秘笈 心 法 

心 法 领悟 008: 使 用 IS 和 PHP 5.3.1 来 配置 PHP 的 开发 环境 。 

如 果 使 用 IS 和 PHP 5.3.1 来 配置 PHP 的 开发 环境 ,那么 本 机 中 必须 安装 微软 的 VC++ 2008(Visual C++ 2008， 
简称 VC++ 2008) 的 运行 库 (veredist_x64.exe 或 者 vcredist x86.exe) 和 FastCGI 扩 展 〈fegisetup32.msi) ， 以 确 
保本 机 的 IS 6 支持 FastCGI。 


初级 


实例 009 趣味 指数 : | 
实例 说 明 


MySQL 是 目前 最 为 流行 的 开放 源码 的 数据 库 , 是 完全 网 络 化 的 跨 平 台 的 关系 型 数据 库 系统 。 它 是 由 MySQL 
AB 公司 开发 、 发 布 并 支持 的 。 任 何人 都 能 从 Intermet 上 下 载 MySQL 软件 ， 并 且 不 需 支 付 任何 费用 。 


PHP 开发 实例 大 全 〈 基 础 老 ) 
在 MySQL 的 官方 网 站 (http://www.mysql.com) 中 可 以 下 载 到 最 新 版 本 的 MySQL 服务 器 。 
图 关键 技术 
在 MySQL 的 官方 网 站 (http://www.mysqlcom) 中 下 载 最 新 版 本 的 MySQL 服务 器 的 具体 步骤 如 下 : 
(1) 打开 正 浏览 器 ， 在 地 址 栏 中 输入 http://www.mysql.com， 进 入 MySQL 的 官方 网 站 ， 如 图 1.26 所 示 。 


图 World s most popular open Source ase 一 Nicre: TInternet Ter 


立 件 们 ”编辑 已) 查看 忆 半 他 工具 人 必 币 如 E23 
9 A 豆 
-日 -着 国 入 | 用 寻 克 x 如 | 仿 - 总 国 
地 直 四 图 Nt: msl cn/ € ME ue* 
a 


AN (BUN "acommended oervers tor mont 
MySQL ) 


The world's most popular open source database 


Inside 


Get the Guide 


(2) 单 击 Downloads 超 链 接 ， 进 入 
文件 中 天 EE 二 Bb 
Oi 日 国 国 移 记 es 实 eex 加 全 :和 局 司 
HE 加 | 手 Mtp://dv wag con/ towndonts 

UC TT 
MySQL ) he i 


3B Solutions ¥ Customer Louin 


Loon | Reoister | 


MySQL Downloads 


MySQL Downloads 
* MySQL software is provided under the GPL License 
» OEMs, ISVs and VARS can purchase Commercial Licenses 


Contact Sales * Learn about MySQL Products and MySQL Services 
UsA Tol Free: +1.386-221-0834 
USA - From abroacs 单 击 超 链接 ， 下 载 MySQL CommunityServer 
+1-208-327-6494 

USA -Suesenpaon Ronewakc; 
OR: Important Platform Support Updates » 


Latin America: +1 512 535 7751 
Us +44 845 359 1124 MySQL Community Server 
reland: +353 1 6919191 

Germany: +ag 99 420 95 99 95 


Current Release (Recommended) 


图 1.27 MySQL Downloads 页 面 
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(3) 单 击 MySQL 5.1 一 Generally Available (GA ) release for production use 超 链接 , 进入 MySQL Connumity 
Server 下 载 页 面 ， 如 图 1.28 所 示 。 


5 了 
ETE TE 

Be- 日 国 国 竹本 去 ex 加 辐 - 癌 蕊 
Tr 


yo Downloads 


» MySQL software is provided under the GPL License 引 


> OEMs, ISVs and VARs can purchase Commercial Licenses 


Products and MySQL Services 
单 击 下 载 按钮 


UEA -Tol Free: +1.866-221-0534 


VEA -From abroad Wo cone fowly avalable 0 
Uist price (US) pe Seartng af $599/sorveryear 
+1-208-327-6404 under the GRL License sl EE 


Orman 


图 1.28 MySQL Connumity Server 下 载 页 面 
(4) 单 击 Download 按钮 ， 进 入 如 图 1.29 所 示 页 面 。 在 该 页 面 中 ， 可 以 选择 安装 的 平台 。 


四 | ESEEE 
ET [3 
@ 右 -日 ,四 国 的 让 晤 次 ex 如 | 全 -总 现 
区 TO 


MySQL 
Newsletter 


Cv 人 


MySQL Community Edit 


downioadab version of the worid's most popular open source 


= 
acabase that ls supported by an actVs community of open source dovelopars and enthuslacts, 


avalable as 3 separate download, The reason for 
er can provide more frequent updates and 5upport 


ve to our Bugs Database, Thank you for your 


SL Ust of changss 
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图 1.29 选择 安装 的 平台 


(5) 这 里 选择 Windows 平台 ， 单 击 Windows 超 链接 ， 进 入 如 图 1.30 所 示 的 页 面 。 在 该 页 面 中 ， 可 以 下 载 


不 同安 装 方式 的 MySQL。 
(6) 单 击 Windows Essentials(x86) 后 面 的 Download 超 链接 , 将 弹出 下 载 对 话 框 , 在 该 对 话 框 中 单 击 “ 保 存 ” 


按钮 ， 下 载 Windows 安装 版 的 MySQL。 


[ED 说 明 : (1) 如 果 在 该 页 面 中 没有 出 现 Download 超 链接 ， 可 以 单 击 Pick a mirror 超 链接 ， 选 择 一 个 镜像 进 
行 下 载 。 

(2) 本 书 在 讲解 MySQL 的 下 载 和 安装 时 使 用 的 是 mysql-essential-5.1.39 版 本 ， 当 读者 看 到 本 书 时 ， 

这 个 版 本 可 能 不 是 最 新 的 版 本 了 。 不 过 MySQL 的 下 载 和 安装 步骤 基本 没有 变化 ， 读 者 仍然 可 以 使 
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用 本 书 中 提供 的 步骤 、 方 法 进行 下 载 和 安装 。 
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图 1.30 MySQL 的 下 载 列表 


图 设计 过 程 
下 面 讲解 MySQL 的 具体 安装 步骤 。 

(1) 双击 下 载 后 的 mysql-essential-5.1.39-win32.msi 文件 ， 打 开 安 装 向 导 对 话 框 ， 单 击 Next 按钮 后 ， 进 入 
Setup Type (选择 安装 类 型 ) 对 话 框 。 在 该 对 话 框 中 ， 共 包括 Typical (典型 )、Complete 完全) 和 Custom ( 自 
定义 ) 3 种 安装 类 型 。 这 里 选择 典型 安装 ， 如 图 1.31 所 示 。 

(2) 单 击 Next 按钮 ， 打 开 准 备 安装 对 话 框 ， 在 该 对 话 框 中 将 显示 默认 的 安装 路 径 ， 单 击 Install 按钮 ， 开 
始 安装 MySQL。 在 安装 的 过 程 中 ， 将 显示 MySQL Enterprise 的 宣传 对 话 框 ， 在 该 对 话 框 中 ， 单 击 Next 按钮 ， 
进入 下 一 个 宣传 对 话 框 ， 再 次 单 击 Next 按钮 ， 将 进入 如 图 1.32 所 示 的 Wizard Completed (成 功 向 导 ) 对 话 框 。 
在 该 对 话 框 中 采用 默认 设置 ， 单 击 Finish 按钮 ， 继 续 安装 MySQL 服务 器 。 


TI ET 
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图 1.31 选择 安装 类 型 对 话 框 图 132 成 功 向 导 对 话 框 


(3) 这 时 将 进入 欢迎 安装 MySQL 服务 器 的 对 话 框 ， 在 该 对 话 框 中 ， 单 击 Next 按钮 ， 进 入 如 图 1.33 所 示 
的 MySQL 服务 器 配置 类 型 对 话 框 。 在 该 对 话 框 中 可 以 选择 详细 配置 或 者 标准 配置 ， 这 里 选择 详细 配置 。 

(4) 单 击 Next 按钮 ， 进 入 如 图 1.34 所 示 的 选择 服务 器 类 型 对 话 框 。 在 该 对 话 框 中 将 提供 开发 者 类 型 、 服 
务 器 类 型 和 致力 于 MySQL 服务 类 型 。 这 里 选择 默认 的 开发 者 类 型 。 

(5) 单 击 Next 按钮 ， 进 入 如 图 1.35 所 示 的 选择 数据 库 用 法 对 话 框 ， 在 该 对 话 框 中 提供 3 个 选项 ， 分 别 是 
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多 功能 型 (Multifunctional Database) 、 仅 提供 事务 型 (Transactional Database Only) 和 仅 不 提供 事务 型 


(Non-Transactional Database Only) 。 这 里 选择 多 功能 型 。 
(6) 单 击 Next 按钮 ， 进 入 如 图 1.36 所 示 的 设置 服务 器 安装 路 径 的 对 话 框 ， 这 里 采用 默认 设置 
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图 1.33 MySQL 服务 器 配置 类 型 对 话 框 图 1.34 选择 服务 器 类 型 对 话 框 
i ep 
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图 1.35 选择 数据 库 用 法 对 话 框 


1.36 设置 服务 器 安装 路 径 对 话 框 


(7) 单 击 Next 按钮 ， 进 入 如 图 1.37 所 示 的 设置 提示 连接 的 数量 的 对 话 框 ， 这 里 采用 默认 设置 。 
(8) 单 击 Next 按钮 ， 进入 如 图 1.38 所 示 的 设置 网 络 选项 对 话 框 ， 在 该 对 话 框 中 采用 默认 设置 。 
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图 1.37 设置 提示 连接 的 数量 的 对 话 框 


图 1.38 设置 网 络 选项 对 话 框 


Cg 技巧 MySQL 使 用 的 默认 端口 是 3306， 在 安装 时 ， 可 以 修改 为 其 他 的 ， 如 3307。 但 是 一 般 情 况 下 ， 不 要 
修改 默认 的 端口 号 ， 除 非 3306 端口 已 经 被 占用 。 
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(9) 单 击 Next 按钮 ， 将 打开 设置 默认 的 字符 集 的 对 话 框 ， 在 该 对 话 框 中 选中 Manual Selected Default 
Character Set/Collation 单 选 按钮 ， 并 在 Character Set (字符 集 ) 下 拉 列 表 框 中 选择 gbk (简体 中 文 ) ， 如 图 1.39 


所 示 。 


(10) 单 击 Next 按钮 ， 进 入 如 图 1.40 所 示 的 设置 Windows 选项 的 对 话 框 ， 这 里 采用 默认 设置 。 
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图 1.39 设置 默认 的 字符 集 对 话 框 


1.40 设置 Windows 选项 对 话 框 


(11) 单 击 Next 按钮 ， 进 入 安全 设置 选项 对 话 框 ， 该 对 话 框 用 于 为 默认 用 户 root 设置 密码 ， 这 里 设置 为 


111， 如 图 1.41 所 示 。 


(12) 单 击 Next 按钮 ， 进 入 准备 执行 对 话 框 ， 单 击 Execute 按钮 ， 完 成 服务 器 配置 ， 配 置 完成 后 ， 将 显示 
如 图 1.42 所 示 的 对 话 框 。 单 击 Finish 按钮 ， 完 成 MySQL 的 安装 。 
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1.41 ”安全 设置 选项 对 话 框 


图 1.42 ”完成 服务 器 配置 


[ED 说 明 : MySQL 安装 完成 后 ， 将 在 “开始 ”/“ 所 有 程序 ”菜单 下 添加 一 个 MySQL 项 ， 在 该 项 中 包括 一 个 
MySQL Server 5.1 子 项 ， 在 该 子 项 下 ， 又 包括 MySQL Command Line Client、MySQL Server Instance 
Config Wizard 和 SunInventory Registration 3 个 子 项 。 其 中 MySQL Command Line Client 为 MySQL 
的 客户 端 命令 行 ， 通 过 该 项 ， 可 以 查看 数据 表 结构 及 执行 SQL 语句 ; MySQL Server Instance Config 
Wizard 项 可 用 于 修改 MySQL 的 配置 ， 如 修改 字符 集 和 root 用 户 的 密码 等 。 


至 此 ，MySQL 安装 成 功 ， 如 果 要 查看 MySQL 的 安装 配置 信息 ， 可 以 通过 MySQL 安装 目录 下 的 my.ini 文 


件 来 完成 。 


在 my.ini 文件 中 ， 可 以 查看 到 MySQL 服务 器 的 端口 号 、MySQL 在 本 机 的 安装 位 置 、MySQL 数据 库 文件 
存储 的 位 置 ， 以 及 MySQL 数据 库 的 编码 等 配置 信息 ， 如 图 1.43 所 示 。 
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图 1.43 myini 文件 的 配置 信息 
秘笈 心 法 


心 法 领悟 009: 设置 MySQL 用 户 的 密码 。 


在 安装 MySQL 数据 库 时 ， 一 定 要 牢记 在 第 〈1) 步 中 设置 的 root 用 户 的 密码 ， 它 是 我 们 在 访问 MySQL 数 
据 库 时 必须 使 用 的 。 


初级 
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本 书 以 Windows 2003 中 使 用 的 IS 6.0 为 例 , 讲解 IS 的 安装 。 至 于 在 其 他 操作 系统 中 的 安装 步骤 是 相同 的 ， 
只 是 使 用 的 版 本 有 所 不 同 。 


图 关键 技术 


IIS 的 安装 非常 简单 ， 关 键 是 如 何 配置 IS 服务 器 。 
(1) 选择 “开始 ”/“ 设 置 ”/“ 控 制 面板 ”命令 ， 在 弹出 的 窗口 中 双击 “管理 工具 ”图 标 ， 在 弹出 的 窗口 
中 单 击 “Internet 信息 服务 (IIS) 管理 器 ”图 标 ， 将 弹出 IS 管理 器 界面 ， 如 图 1.44 所 示 。 
(2) 图 中 的 “默认 网 站 ” 即 为 IS 服务 器 的 文件 目录 。 右 击 “ 默 认 网 站 ”， 在 弹出 的 快捷 菜单 中 选择 “ 属 
性 ”命令 ， 弹 出 “默认 网 站 属性 ”对 话 框 ， 可 在 其 中 设置 网 站 的 属性 ， 如 图 1.45 所 示 。 
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图 1.44 IIS 管理 器 界面 图 1.45 “默认 网 站 属性 ”对 话 框 
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(3) 默认 选中 的 是 “网 站 ”选项 卡 ， 在 其 中 可 以 设置 TCP 端口 号 ， 这 里 将 IS 端口 号 设置 为 “82”。 设 置 
完成 后 选择 “ 主 目录 ”选项 卡 ， 如 图 1.46 所 示 。 
(4) 在 “ 主 目录 ”选项 卡 中 进行 3 项 设置 : 第 1 项 是 设置 本 地 路 径 , 用 户 可 以 自行 定义 , 如 FAPkhiisPHP\www; 


第 2 项 是 设置 执行 权限 ， 这 里 设置 为 纯 脚本 ; 第 3 项 是 添加 PHP 的 支持 。 单 击 “ 主 目录 ”选项 卡 中 的 “配置 ” 
按钮 ， 弹 出 如 图 1.47 所 示 的 “应 用 程序 配置 ”对 话 框 。 


目录 人性 | jmrP 半 | 自 定 X 桂 误 | IISAraemite | 
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图 1.47 应 用 程序 配置 

(5) 选择 “映射 ”选项 卡 ， 完 成 添加 、 编 辑 应 用 程序 扩展 。 单 击 “ 添 加 ”按钮 ， 在 弹出 的 如 图 1.48 所 示 
对 话 框 中 首先 指定 可 执行 文件 ， 这 里 指定 的 是 存储 在 系统 盘 的 system32\inetsrv\ 文 件 夹 下 的 fcgiext.dll 文件 ， 然 
后 设置 扩展 名 为 “.php”， 最 后 单 击 “ 确 定 ”按钮 ， 返 回 到 “默认 网 站 属性 ”对 话 框 。 

(6) 选择 “文档 ”选项 卡 ， 添 加 一 个 .php 的 默认 页 。 添 加 后 的 效果 如 图 1.49 所 示 。 


图 1.46 “ 主 目录 ”选项 卡 
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图 1.49 添加 默认 页 


1.48 添加 PHP 扩展 
(7) 关闭 所 有 对 话 框 ， 重 启 IS 服务 器 。 
图 设计 过 程 
(1) 选择 “开始 ”/“ 设 置 ”/“ 控 制 面板 ”命令 ， 在 弹出 的 窗口 中 单 击 “ 添 加 /删除 程序 ”按钮 。 


(2) 单 击 左 侧 的 “添加 /删除 Windows 组 件 ” 按 钮 ， 弹 出 “Windows 组 件 向 导 ” 对 话 框 。 依 次 选中 并 双击 
“Windows 组 件 向 导 ” 对 话 框 中 的 “应 用 程序 服务 器 ”选项 、“ 应 用 程序 服务 器 ”窗口 中 的 “Internet 信息 服务 
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(IIS) ”选项 、“Intemet 信息 服务 (IS) ”对 话 框 中 的 “万 维 网 服务 ”选项 。 最 后 选中 “万 维 网 服务 ” 复 选 框 。 
(3) 设置 完毕 后 单 击 “ 确 定 ” 按 钮 。 具 体操 作 过 程 如 图 1.50 所 示 。 
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1.50 Intemet 信息 服务 (IIS) 
安装 完成 后 即 可 使 用 IS。 
秘笈 心 法 


心 法 领悟 010， 测试 IIS 是 否 安装 成 功 。 

安装 IS 后 ， 即 可 在 正 浏览 器 的 地 址 栏 中 输入 http://localhost， 测 试 HS 是 否 安装 成 功 。 

如 果 本 机 的 80 端口 被 Apache 占用 ， 那 么 就 需要 修改 IS 的 端口 号 。 例 如 修改 为 82 端口 ， 那 么 测试 时 应 该 
在 地 址 栏 中 输入 http://localhost:82/。 


一 一 
图 实例 说 明 


本 实例 编写 第 3 个 PHP 脚本 ， 在 IS 服务 器 下 运行 ， 测 试 通过 IS+PHP+MySQL 搭建 的 PHP 开发 环境 是 否 
成 功 ， 运 行 结果 如 图 1.51 所 示 。 


本 文 作品 ”后 作 Q 查看 W) 窗口 W) 得 吕 | = 村 
人 地 | 白 回 | 多 日 | 国 轩 | 忌 | ， 1 
图 et 全 请 服务 
Ee 

RY 
Ds 


IIStPHPHIYSQL 独 立 棋 建 PEP 开 发 环境 测试! 


I l 
1.51 测试 独立 环境 是 否 措 建 成 功 


图 关键 技术 


确定 IS 服务 器 设置 的 本 地 路 径 , 这 是 在 IS 的 配置 中 完成 的 ， 必 须 将 PHP 脚本 存储 于 IIS 设置 的 本 地 路 径 
下 才能 够 运行 。 


PHP 开发 实例 大 全 (基础 卷 ) 


图 设计 过 程 
(1) 在 IIS 指定 的 本 地 路 径 下 〈F:\PkhiisPHP\www) 新 建 一 个 文本 文档 ， 在 该 文档 中 输入 如 下 内 容 : 
Ce 独立 搭建 PHP 开发 环境 测试 !"; 


(2) 将 该 文档 重 命名 为 index.php。 

(3) 选择 “开始 ”/“ 设 置 ”"/“ 控 制 面板 ”命令 , 在 弹出 的 窗口 中 双击 “管理 工具 ”图 标 , 然后 选择 “Internet 
信息 服务 〈IS) 管理 器 ”选项 ， 依 次 展开 “本 地 计算 机 ”和 “网 站 ”节点 ， 右 击 “ 默 认 网 站 ”选项 ， 在 弹出 的 
快捷 菜单 中 选择 “浏览 ”命令 ， 若 在 “Intemnet 信息 服务 〈IS) 管理 器 ”窗口 的 右 侧 输出 如 图 1.51 所 示 的 内 容 ， 
说 明 独 立 环境 搭建 成 功 。 


秘笈 心 ; 


心 法 领悟 011: IS 中 的 UrlRewrite 技术 。 

UrlRewrite 即 地 址 变换 ， 可 以 实现 静态 功能 ， 方 便 搜 索引 擎 收录 ， 比 如 http://***/news.php?id=1 可 以 变 为 
htt://***/news-1.html。 不 但 可 以 实现 开发 标记 的 隐藏 ,而 且 避 免 每 个 页 面 都 输出 .php 后 级 ， 进 而 提高 网 站 的 安 
全 性 。 

IIS 默认 是 不 支持 此 功能 的 ， 需 要 单独 安装 插件 ISAPI_Rewrite3_0048_Lite.msi。 安 装 完成 后 打开 IS， 在 
Web 属性 的 “ISAPI 筛选 器 ”里 添加 位 于 安装 目录 的 HeliconSAPI Rewrite3 文件 夹 里 的 ISAPI Rewrite.dll 即 可 ， 
名 称 可 以 自 定义 。 


1.4 LAMP 一 一 独立 配置 PHP 开发 环境 


在 Linux 下 搭建 PHP 环境 比 在 Windows 中 要 复杂 一 些 ， 除 了 Apache、PHP 等 软件 外 ， 还 要 安装 一 些 相关 
工具 ， 并 设置 必要 参数 。 这 里 给 出 在 Linux 下 搭建 PHP 环境 的 必要 步骤 ， 如 果 用 户 在 安装 过 程 中 遇 到 特殊 的 问 
题 ， 还 需要 翻阅 与 Linux 相关 的 资料 、 书 籍 或 者 手册 。 

安装 之 前 要 准备 的 安装 包 如 下 : 

回 apache 1.3.41.tar.gz 

回 php-5.0.0.tar.gz 

Inysql-standard-5.0.0-alpha-pc-linux-i686.tar.gz 

libxml2-2.6.19.tar.gz 


[ED 说 明 : 本 书 中 在 讲解 Linux 下 搭建 PHP 开发 环境 时 ， 使 用 的 软件 版 本 相对 较 低 ， 如 果 读 者 想 要 下 载 这 些 软 
件 ， 可 以 登录 http://221.8.65.77/mrbook/bookzy/linux.rar。 
这 里 首先 在 Linux 系统 的 /usr/local/ 文 件 夹 下 新 建 一 个 work 文件 夹 ,并 将 使 用 的 软件 全 部 存储 在 此 文件 夹 下 。 


| 


实例 012 趣味 指数 : obodolod 


力 实例 说 明 


本 实例 讲解 在 Linux 操作 系统 下 安装 Apache 服务 器 。Apache 服务 器 安装 成 功 后 测试 的 运行 结果 如 图 1.52 
所 示 。 
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总 四 LJ 
| 文 作 四。 坊 忽 EE) 查看 CD 特 球 G@) 书 容 B 工 尼 D 窗口 Ww》 有 有 助 四 || 


到 ” 候 旧 ”重新 增 入 打印 
| 盟主 页 遗书 答 参 Red Hat Network 泗 Sppont 前 Shop 舞 Products 区 Training 


| 
| 息 - 况 - 时 ”可 [ipanov [vB 吕 > 
| 


| 
| 

Apache 的 文件 已 经 包含 在 该 版 本 中 。 
你 可 以 在 使 用 Apache 的 网 站 伺服 器 上 ， 自 由 的 使 用 下 面 之 图 示 ， 感 潮 你 | 
使 用 Apache ! | 
| 


“i ACE 


泥 囊 风 国 | 基态 [i 


图 1.52 Apache 配置 成 功 


图 关键 技术 


Linux 系统 下 配置 Apache 服务 器 使 用 的 仍 是 httpd.conf 文件 ， 该 文件 位 于 /usr/local/apache/conf 中 。 
(1) 在 httpd.conf 文件 中 ， 定 位 到 如 图 1.53 所 示 的 位 置 ， 添 加 相应 的 内 容 ， 并 设置 PHP 文件 的 后 组 。 
(2) 同样 在 httpd.conf 文件 中 ， 定 位 到 如 图 1.54 所 示 的 位 置 ， 设 置 PHP 文件 的 默认 页 。 


soarehe/eon ttnd en 
文 作坊 名 EE) 查看 (V) 搜索 3 工具 了 。 文档 (D) 有 有 助 t 
加 加 .加 | 久 /9 人 @ 旬 DDG, 
新 建 打开 保存 打印 撤消 乎 复 剪 切 复制 粘贴 查找 

站 wpdeonte x 


文 八 ED 蛇 镍 (EE) 。 查看 (V) 搜索 (工具 ID。 文档 ID 帮助 (H) 


苹 鲁 .加 | 钙 le 区 虽 白 | 己 ， 


新 建 打开 。 保存 打印 撤消 平复 ”前 切 复制 籼 同 ”查找 


apdeont x 


目标 定位 
AdiType_ application/x-gzip .gz .gz 
ATYpe_application/x-hupd- php_ ,php MMME) .php4 
大 | 


添加 内 容 
# AddHandlar_ allows_vou tn_man_certain 有 
行 774, 列 43 插入 


1.53 ”设置 文件 后 缀 图 1.54 设置 默认 文件 
图 设计 过 程 
安装 Apache 服 务 器 ,首先 需要 打开 Linux 终端 (Linux 下 几乎 所 有 的 软件 都 需要 在 终端 下 安装 )。 选 择 RedHat9 
的 “ 主 菜单 ”/“ 系 统 工具 ”命令 ， 在 弹出 的 子 菜单 中 选择 “终端 ”命令 。Apache 服务 器 的 安装 步骤 如 下 : 
(1) 解压 apache_1.3.41.tar.gz 压缩 包 ， 将 其 存储 到 /urllocal/apache 目录 下 ， 执 行 的 命令 如 图 1.55 所 示 。 


NM east/ vor 34 x 
ET | 


《lfModule mod_dir.c> 
DirectoryIndex index.html [index.phg] 
IIModule> 


扩 
AdjType application/x-compress 了 


行 364, 列 40 


Wr 1 
installation path layout: Apache (config. layout) 
ia Miefile 

[Greating Configuration.apaci in sre 

[Greating Mkefile in sre/support 

[Greating Mkefile in sre/regex 


‘2 Mkefil Juni 


eR 代码 导读 
@ 进入 Apache 安装 文件 的 目录 。 
@ 解压 Apache 服务 器 的 安装 包 。 
目 进入 apache 1.3.41 目录 。 
@ 将 Apache 服务 器 安装 到 /usr/local/apache 目录 下 。 


PHP 开发 实例 大 全 (基础 卷 ) 


(2) 执行 make 命令 ， 编 译 apache 文件 。 执 行 命令 如 图 1.56 所 示 。 
(3) 执行 make install 命令 ， 开 始 安 装 Apache 服务 器 。 执 行 命令 如 图 1.57 所 示 。 
BA sooo/s/ba ot 3 


文件 ED 编辑 人 E) ”查看 (V) ”终端 D 。 转 到 KG) 帮助 四 
+ checking for system header files 

+ adding selected mdules 

+ using system Expat 

+ using -1d1 for vendor DSO suppor! 

+ checking sizeof various data types 

+ doing sanity check on conpiler and options 

ng Mkefile in sre/sepport 

ng Mkefile in sre/regex 


文件 四。 编辑 (E) ”查看 (V) ”终端 D ” 转 到 (G) ”帮助 由 
mkel1]: Leaving directory /usr/local/wrk/apache_1.3.41" 


mke[2]: Entering directory “/usr/local/work/apache_1.3.41/sre’ ===> [nktree: Crea ting Apache installation tree] 
=- sre/regex Lsre/e tpers/mkdir .sh /usr/ localapache/bin 


图 1.56 执行 make 命令 编译 文件 图 1.57 执行 make install 安装 命令 
(4) Apache 服务 器 安装 成 功 后 ， 将 给 出 如 图 1.58 所 示 的 命令 提示 。 


~ PT TT EE 人 X 
文件 已 坊 辑 (E) ”查看 (VI 。 终端 了。 特 到 @) 帮助 QD 
make[1]:; Leaving directory /usr/local/work/apache_l 


| You now have successfully built and installed the 
| Apache 1.3 HTTP server- To verify that Apache actually 
| works correctly you now should first check the 

| Cinitially ereated or preserved) configuration files 


1 
1 /usr/local/apache/conf/httpd.conf 
1 

| and then you should be able to immediately fire up 
| Apache the first Line by running: 


1 
| oust/local/apache/bin/apachectl start 
1 
| Thanks for using Apache The Apache Group 

1 hitp:// ww.apache .org/ 


图 1.58 ”安装 成 功 返回 命令 


图 秘笈 心 法 


心 法 领悟 012，Linux 下 启动 Apache。 

安装 成 功 后 ， 就 可 以 启动 Apache 服务 器 了 ， 启 动 Apache 服务 器 使 用 的 命令 如 图 1.59 所 示 。 
~ Er 
| 文人 (BD 编 名 EE) 查看 (Ww 奖 洋 DD 转 玛 @)。 邦 WD | 
[root@loca lhost apache_1.3.41]# /usr/local/apache/bin/apachect! start 


usr/ local/apache/bin/apachectl start: httpd started 
root rec thost apsche 1.3.41]s 


图 1.59 执行 启动 Apache 服务 器 的 命令 


实例 013 


力 实例 说 明 


osteo pt/ 2 


本 实例 讲解 在 Linux 下 安装 MySQL 数据 库 , 使 用 的 版 本 是 mysql-standard-5.0.0- alpha- pc- linux-i686 .tar.gz。 


力 关键 技术 
(1) 在 Linux 操作 系统 中 ， 备 份 和 还 原 MySQL 使 用 的 命令 如 下 : 


第 1 章 开发 环境 
备份 : 


mysqldump -uroot -proot -R 数据 库 名 称 >C:/data.sql 
还 原 : 
mysql -uroot -proot-D 数据 库 名 称 < C:/data.sql 
(2) 在 Linux 操作 系统 中 ， 设 置 和 修改 root 用 户 密码 的 命令 如 下 : 
设置 密码 ;: 
mysqladmin —uroot password root 
修改 密码 : 
mysqladmin -uroot -p 旧 密 码 password 新 密码 
图 设计 过 程 
下 面 讲解 其 具体 的 安装 步骤 。 
(1) 安装 MySQL 数据 库 同样 要 在 Linux 终端 的 命令 中 进行 。 首 先 创建 MySQL 账号 ， 并 将 新 建 账号 加 入 
到 组 群 ， 具 体 使 用 的 操作 命令 如 图 1.60 所 示 。 


ou have to copy support-riles/mysql.serve' 
system 


th tbe benchomrks in the 


a sat-bench’ sisectory: | 
图 1.60 MySQL 的 安装 命令 


eR 代码 导读 

创建 MySQL 账号 。 

加 入 组 群 。 

进入 MySQL 安装 文件 的 目录 。 

解压 MySQL 服务 器 软件 。 

以 链接 的 方式 建立 /usrllocalmysql 目录 。 

进入 MySQL 目录 。 

在 /usr/local/mysql/data 中 建立 MySQL 数据 库 。 


(2) 在 完成 数据 库 的 安装 之 后 ， 修 改 文件 的 权限 。 具 体操 作 命令 如 图 1.61 所 示 。 


oooceooeoeoe 


sql-bench’ dir 
ript! 
sbout MSQL is available on the web at 


thttps://order .rysql .com 


1 
[root@loca lhost mysqll# lchgrp -R msql . 


图 1.61 修改 文件 权限 的 命令 
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(3) 完成 权限 修改 后 ， 看 一 下 启动 MySQL 服务 器 的 命令 。 具 体 命 令 如 图 1.62 所 示 。 


文 作 E) 编辑 E) 查看 终 奖 了。 转 于 G) 帮助 细 
| oca Ihost nysql]#[/usr7Ioca I7rysql/bin/nysqlds 
1 


1.62 启动 MySQL 的 命令 


国 秘 稚 心 法 


心 法 领悟 013: Linux 下 修改 MySQL 数据 库 用 户 的 密码 。 
可 以 通过 命令 修改 MySQL 数据 库 用 户 的 密码 .在 如 图 1.63 所 示 的 命令 中 ,首先 以 无 密码 的 方式 登录 MySQL 
数据 库 ， 然 后 通过 命令 设置 MySQL 数据 库 用 户 的 密码 ， 最 后 通过 新 设置 的 密码 重新 登录 MySQL 数据 库 。 


“~ Er x 
| 文件 E) 编辑 EE) ”查看 (V) 疼 油 DD 转 至 G) 有 盈 ) | 
Jroot@loca lhost nysql]# [usr7Tocn T7177 00 | | 
(Wleone to the MSQL nonTior. Commn ror wg. | | 
Your MSOQL connection id is 1 to serve 5.0.0-aIpha— STandard— 


Type “help:’ or '\h"’ for help. Type '\e' to clear the buffer. 


[yet wa ER 

[Bye i 

[root@loca lhost nysql]# E 
[root@loca Ihost nysql]# [usr7Toca Tny sq TP In7 nyaT “uroor “Prod!] 
Wlcone to the MSQL nmonitor. Conmnds end wi 


说 MSQL connection id is 4 to server versii 


| "help;i' or '\h’ for help. Type '\e’ to char the buffer. 
| we | 
图 1.63 登录 MySQL 和 设置 MySQL 登录 密码 


中 级 
趣味 指数 : 富 坪 商 穴 


实例 说 明 


本 实例 讲解 在 Linux 操作 系统 下 安装 PHP 5.0。 安 装 之 前 , 首先 需要 查看 libxml 的 版 本 号 , 如 果 小 于 2.5.10， 
则 需要 先 安装 libxml 的 高 版 本 ， 否 则 ， 可 以 直接 安装 PHP 5.0。 


力 关键 技术 


这 里 以 libxml2-2.6.19.tar.gz 为 例 ， 讲 解 libxml 的 安装 步骤 。 
(1) 将 libxml2-2.6.19.tar.gz 进行 解压 ， 并 将 其 安装 到 指定 的 文件 夹 下 ， 其 操作 命令 如 图 1.64 所 示 。 


~ rr rr 二 x 
| 文 (KB 编辑 (E) ”查看 (VW 终端 D 转 


图 1.64 解压 libxml 


ES 
ER 代码 导读 
@ 进入 /usrlocal/work 文件 夹 〈libxml2-2.6.19 压缩 包 存 储 的 位 置 ) 。 


@e 
- 
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四 解压 libxml2-2.6.19.tar.gz。 
目 进入 libxml2-2.6.19 文件 夹 。 
@ 将 libxml2-2.6.19 安装 到 /usrlocallibxml2。 


(2) 完成 libxml 的 解压 后 ， 开 始 编译 文件 ， 使 用 的 命令 如 图 1.65 所 示 。 
(3) 文件 编译 完成 后 ， 就 可 以 执行 安装 操作 了 ， 使 用 的 命令 如 图 1.66 所 示 。 


| 回 LjL 
转 到 @) 


帮助 


图 1.65 编译 文件 


图 设计 过 程 
本 书 使 用 的 版 本 是 php-5.0.0.tar.gz。 下 面 来 看 具体 的 安装 步骤 。 
(1) 将 php-5.0.0.tar.gz 解压 到 指定 的 文件 夹 下 ， 通 过 命令 进行 配置 ， 使 用 的 操作 命令 如 图 1.67 所 示 。 


[EX 
终端 转 到 G) 帮助 


Y 
文件 BD。 坊 辑 E) 查看 (办 
[ 


Toea 
AT NE-S OO Tar ET 
TTT]e 
——with-apxs=/usr/local/apache/bin/apxs \ 
ibxml-dir=/usr/ local/ libxml2 一 enable-sock| 


1.67 安装 PHP 


ok 
eS 代码 导读 
@ 进入 /usrlocal/work 文件 天 《php-5.0.0.tar.gz 压缩 包 存 储 的 位 置 ) 。 
@ 解压 php-5.0.0.tar.gz。 
目 配置 文件 。 


(2) 完成 解压 和 配置 操作 后 ， 对 文件 进行 编译 ， 使 用 的 命令 如 下 : 

make 

(3) 编译 完成 后 ， 执 行 安装 操作 ， 使 用 的 命令 如 下 : 

make install 

(4) 最 后 ， 在 命令 中 将 出 现 如 图 1.68 所 示 的 内 容 ， 说 明 PHP 安装 成 功 。 


~ PTET TT 一 呈 
件 (EE 坊 辑 (ED 查看 (由 兰 痪 D。 转 到 G) 新山 


ost php-5.0.018 上 


> = 
图 1.68 PHP 安装 成 功 
国 秘笈 心 法 


心 法 领悟 014: 在 Linux 下 创建 php.ini。 
在 Linux 操作 系统 中 ，PHP 的 配置 文件 仍然 是 php.ini， 其 创建 方法 如 下 : 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


在 PHP 文件 夹 下 找到 php.ini-dist 或 者 php.ini-recommended， 将 其 复制 到 /usr/local/lib 目录 下 ， 并 重 命名 为 


php.ini。 
cp php.ini-dist /usr/local/lib/php.ini 


中 级 
起 呆 撒 娄 ， 宙 六 个 


实例 015 


力 实例 说 明 


在 Linux 系统 下 搭建 完成 PHP 开发 环境 后 ， 编 写 一 个 小 实例 ， 测 试 环境 是 否 拱 建成 功 。 在 Mozilla 浏览 器 
的 地 址 栏 中 输入 http://localhost/test.php， 运 行 结果 如 图 1.69 所 示 。 
Er _ 书 答 四 ITROD 座 DQD 帮助 四 二 | 


访 Sn MB 或 - 


前 进 匣 新 载 入 正 


盘 计 页 | 寻 书 签 大 Red Hat Newak 散 Sappon 散 Sshm 区 Prodocts 前 Te 


im localhost Jocakdomain 24.20-8 #1 Thu Mar 13 17:54:28 EST 2003 686 
[Build Date [May 5 2006 104308 


' 


L 
| 
| 


1.69 测试 运行 结果 


图 关键 技术 

在 Linux 操作 系统 下 ， 通 过 gedit 工具 编写 PHP 脚本 。 
图 设计 过 程 

通过 gedit 工具 编写 一 个 PHP 脚本 testphp， 并 存储 于 Apache 的 htdocs 文件 夹 下 。testphp 的 代码 如 图 1.70 
所 示 。 


| 加 Ej 
文 作 (E) 坊 辑 EE) ”查看 (VW) 。 搜索 (3) 工具 D 文档 D) 帮助 由 


久久 . 回 | 号 | 多 人 贡 罩 自 区 ， 


新 建 打开 。 保存 打印 的 消 再 复 ”前 切 复制 粘贴 ”查找 
FD estphp x 
[php 
phpinfo0: 
2> 
行 2, 列 5 插入 


图 1.70 testphp 文件 的 内 容 
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心 法 领悟 015: Linux 下 安装 XAMPP 集成 环境 。 
本 实例 介绍 的 是 在 Linux 操作 系统 下 独立 搭建 PHP 的 开发 环境 ， 读 者 也 可 以 使 用 XAMPP 的 
xampp-linux-1.7.3a.tar.gz 版 本 直接 在 Linux 操作 系统 下 搭建 集成 的 开发 环境 。 


1.5 XAMPP 一 一 Linux 版 PHP 集成 化 安装 包 


前 面 已 经 介绍 过 如 何在 Windows 操作 系统 下 应 用 XAMPP 集成 化 安装 包 配 置 PHP 的 开发 环境 ， 这 里 将 介 
绍 如 何在 Linux 操作 系统 下 通过 XAMPP 配置 PHP 的 开发 环境 以 及 其 基本 应 用 。 


趣味 指数 : 食 食 诬 谷 


力 实例 说 明 
在 Linux 操作 系统 下 ， 也 可 以 使 用 集成 的 软件 来 配置 PHP 开发 环境 ， 它 就 是 XAMPP 的 Linux 版 。 配 置 成 


功 后 ， 在 Mozilla 浏览 器 的 地 址 栏 中 输入 http://127.0.0.1/index.php， 运 行 结果 如 图 1.71 所 示 。 


YY IE 
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二 主页 | 不 书 签 机 Red Hat Network 落 Soppon 萝 Shop 项 pmduds 站 Tnining 
[DH XAMPP for Linux 
以 天 
注 地 闷 国 | 完成 -or 


1.71 Linux 版 的 XAMPP 


国 关键 技术 


在 Linux 操作 系统 下 安装 XAMPP， 必 须 在 Linux “ 主 菜单 ”/“ 系 统 工具 ”下 的 “终端 ”命令 中 通过 指令 
来 完成 ， 切 记 不 要 使 用 任何 微软 操作 系统 下 的 工具 来 进行 操作 。 


图 设计 过 程 


Linux 下 安装 XAMPP 的 步骤 如 下 : 


q 


PHP 开发 实例 大 全 (基础 卷 ) 


(1) 在 Linux 操作 系统 下 ， 选 择 “ 主 菜单 ”/“ 系 统 工具 ”/“ 终 端 ” 命令 。 

(2) 在 命令 模式 下 ， 首 先进 入 系统 的 根 目录 。 

(3) 通过 mkdir 命令 在 根 目 录 下 创建 一 个 opt 目录 。 

(4) 通过 tar xvfz 命令 将 xampp 解压 缩 到 opt 目录 下 。 

(5) 按 Enter 键 ， 执 行 XAMPP 的 解压 缩 ， 直 到 安装 成 功 ， 其 具体 使 用 的 命令 如 图 1.72 所 示 。 
(6) 安装 成 功 后 ， 查 看 /optlampp 目录 ， 如 图 1.73 所 示 。 


文件 E) 编辑 EE) ”查看 (WD 。 转 到 (G) ”书签 B) ”帮助 由 


qq -aa @% A 
后 退 ”前进 ”向 上 一 级 停止 刷新 ， 主 文件 燃 图 
位 置 。 [ET | -B+ | View as los > 

r lhos bmn 

[root@localhost /]# tar xvfz xanpp-linux-1.5.3a.tar.gz -C /op!| 号 < 
选中 了 “bmpp” (有 20 项 ) 

图 1.72 XAMPP 的 安装 图 1.73 查看 安装 的 内 容 
光 
秘笈 心 法 


心 法 领悟 016: Linux 下 安装 XAMPP 的 注意 事项 。 
在 Linux 操作 系统 下 执行 XAMPP 的 解压 缩 时 ， 必 须 进入 系统 的 根 目录 下 ， 并 在 根 目录 下 创建 一 个 子 目 录 ， 
然后 才 可 以 执行 解压 缩 的 命令 ， 否 则 将 提示 找 不 到 指定 的 目录 或 者 文件 。 


. 
动 XAMPP 中 级 | 


力 实例 说 明 


在 实例 016 中 , 已 经 介绍 了 如 何在 Linux 操作 系统 下 安装 XAMPP， 本 实例 我 们 将 介绍 在 Linux 操作 系统 下 
如 何 启 动 XAMPP， 其 使 用 的 命令 如 图 1.74 所 示 。 


~ 
文件 (E) 编辑 EE) 查看 (WD 终端 D 和 转 至 @) 帮助 内 
/opt/ lanpp/ lanpp start 

Linux 1.5.3a.. 


Star ting XANPP 
XAMPP: h SSL (and PHPS)... 


1.74 ”启动 XAMPP 


力 关键 技术 
在 Linux 操作 系统 下 启动 XAMPP， 同 样 要 进入 Linux “ 主 菜 单 ”/“ 系 统 工具 ”下 的 “终端 ”命令 中 ， 所 


使 用 的 命令 如 下 : 
/opt lampp/lampp start 


图 设计 过 程 
Linux 下 启动 XAMPP 的 步骤 如 下 : 


第 1 章 开发 环境 


(1) 在 Linux 操作 系统 下 ， 选 择 “ 主 菜单 ”/“ 系 统 工具 ”/“ 终 端 ” 命 令 。 

(2) 直接 输入 命令 /opt/lampp/lampp start。 

(3) 按 Enter 键 ， 执 行 XAMPP 的 启动 操作 。 命 令 运行 结果 如 图 1.75 所 示 。 
ee 


图 1.75 XAMPP 启动 成 功 


图 秘笈 心 法 
心 法 领悟 017: 停止 XAMPP 的 命令 。 


Linux 下 停止 XAMPP 的 命令 如 下 : 
/opt/lampp/lampp stop 


到 


力 实例 说 明 


在 XAMPP 中 ， 默 认 情况 下 通过 phpMyAdmin 以 root 用 户 的 身份 登录 MySQL 数据 库 是 不 需要 密码 的 ， 
为 了 确保 数据 库 的 安全 ， 应 该 给 root 用 户 设置 一 个 密码 。 这 就 是 本 实例 要 介绍 的 内 容 一 一 如 何 为 root 用 户 设置 
密码 。 


图 关键 技术 


在 Linux 操作 系统 下 为 MySQL 数据 库 的 root 用 户 设置 密码 使 用 的 命令 如 下 : 
rn 
图 设计 过 程 
Linux 下 设置 MySQL 数据 库 root 用 户 密码 的 步骤 如 下 : 
(1) 在 Linux 操作 系统 下 ， 选 择 “ 主 菜单 ”/“ 系 统 工具 ”/“ 终 端 ” 命 令 。 
(2) 直接 输入 命令 /opt/lampp/bin/mysqladmin -u root password "111"， 这 里 设置 root 用 户 的 密码 为 “111”。 
(3) 按 Enter 键 ， 执 行 该 命令 ， 其 运行 结果 如 图 1.76 所 示 。 


图 1.76 设置 root 用 户 的 密码 


国 秘笈 心 ; 
心 法 领悟 018: 卸载 XAMPP 命令 。 
Linux 下 印 载 XAMPP 的 命令 如 下 : 


mm -rf /optlampp 


PHP 开发 实例 大 全 (基础 卷 ) 


趣味 指教: 三 页 让 从 } 


目 


力 实例 说 明 


Linux 系统 下 PHP 的 集成 开发 环境 XAMPP 已 经 配置 成 功 ， 下 面 编写 一 个 小 实例 ， 应 用 phpinfo0 函 数 输出 
PHP 的 配置 信息 ， 通 过 这 个 实例 熟悉 一 下 在 Linux 下 XAMPP 的 运用 。 在 Mozilla 浏览 器 的 地 址 栏 中 输入 
http://127.0.0.1/text/index.php， 运 行 结果 如 图 1.77 所 示 。 


加 
文件 E) 编辑 E) ”查看 (VW 转 到 (@) 书签 BB) 工具 D 请 口 (W) 帮助 -由 


-和 - 妃 所 
襄 -高 - 晶 、 轩 [| 记 wrmpronrewvaaephp 


锐 主 页 | 夺 书 签 秽 Red Hat Netwek 区 Suppart 区 sm 站 pw 痢 maiae 


[Se Lm Rodtiocomain 24208 有 Th Mar 13 17.54.28 EST 2009 WH6 
ua Dae [My 5 2006 Ma 
rr er 
mr。 | 一 wireone 忌 opVaanpy dable debag -enablebemath 
ad nable- dba cand path ae ea 
eable gd-native-nf vy 
“enable ane a 
wp py 


enable-sigehild” —ensble-sysvsem a 


| EE I Peis 


图 1.77 输出 PHP 的 配置 信息 


图 关键 技术 


在 Linux 操作 系统 下 运用 XAMPP 开发 PHP 程序 ， 首 先 要 确立 XAMPP 的 程序 运行 文件 夹 ， 即 明确 创建 的 
程序 要 存储 在 哪个 文件 夹 中 才 可 以 运行 。XAMPP 中 的 重要 档案 和 目录 如 下 : 
/opt/lampp/bin/: XAMPP 指令 的 根 目录 。 例 如 ，/opt/lampp/bin/mysql 用 来 执行 MySQL。 
/opt/lampp/htdocs/: Apache 文件 根 目录 。 
/opt/lampp/etc/httpd.conf: Apache 设 定 档案 。 
/optlampp/etc/my.cnf: MySQL 设 定 档案 。 
/opt/lampp/etc/php.ini: PHP 设 定 档案 。 
/opt/lampp/phpmyadmin/config.inc.php: phpMyAdmin 设 定 档案 。 
看 设计 过 程 

在 XAMPP 中 开发 PHP 程序 的 操作 步骤 如 下 : 

(1) 首先 通过 gedit 工具 编写 一 个 PHP 脚本 ， 应 用 phpinfo0 函 数 输 出 PHP 的 配置 信息 ， 如 图 1.78 所 示 。 


(2) 选择 图 1.78 中 的 “文件 ”/“ 另 存 为 ”命令 ， 将 该 文件 存储 于 XAMPP 的 htdocs/ 目 录 下 ， 并 且 命名 为 
index.php， 如 图 1.79 所 示 。 


加 回回 回回 加 


新 建文 件 夹 (N) | 蓟 除 文件 DD | 重 命名 文件 BR 


/opVlampp/htdocs ~ 
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| index.html | 


~v 转 1 gedit 
文件 四 ”编辑 E) ”查看 (WW 搜索 8) 工具 WD 文档 D) 帮助 由 
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(BD.QS ee, 


新 建 打开 保存 打印 撤消 至 各” 剪 切 复制 粘贴 ”查找 


口 来 三 各 于 % 选中 (8): /opVlampp/htdors 
php - B 

echo phpinfoo [index pi 

?> 


行 2, 列 16 插入 
图 1.78 编辑 PHP 脚本 文件 图 1.79 完成 PHP 文件 的 存储 
(3) 在 Mozilla 浏览 器 的 地 址 栏 中 输入 http://127.0.0.1/text/index.php， 运 行 结果 如 图 1.77 所 示 。 
秘笈 心 法 


心 法 领悟 019: Linux 下 修改 MySQL 默认 字符 集 。 
在 Linux 下 修改 MySQL 默认 字符 集 为 utfg， 操 作 的 文件 是 my.cnf， 操 作 的 内 容 如 下 : 


[client] 
default_character_set=utf8 


[mysqld] 

# default-character-set=utf8 
character-set-server = utf8 
collation-server = utf8_general_ci 
[mysql] 
default_character_set=utf8 


1.6 Dreamweaver 开发 工具 


Dreamweaver 是 Macromedia 公司 开发 的 Web 站 点 和 应 用 程序 的 专业 开发 工具 ， 它 将 可 视 布 局 工具 、 应 用 
程序 开发 功能 和 代码 编辑 组 合 在 一 起 。 


实例 020 趣味 指数 : 请 请 雪 家 
实例 说 明 


应 用 Dreamweaver 开发 网 站 ,首先 必须 考虑 网 页 的 编码 格式 的 选择 。 如 果 网 页 的 编码 格式 有 局 限 性 ， 
那么 将 导致 网 站 在 一 些 特定 的 情况 下 运行 时 出 现 乱 码 ， 将 不 利于 网 站 程序 的 后 期 更 新 和 维护 。 例 如 ， 如 
果 网 站 在 编写 时 使 用 的 是 GB2312 编码 ， 当 程序 在 繁体 操作 系统 中 运行 时 就 会 出 现 乱码 ， 结 果 如 图 1.80 
所 示 。 
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1.80 ”繁体 操作 系统 下 查看 GB2312 编码 格式 文件 与 源 文件 对 比 


图 关键 技术 


对 于 网 站 的 开发 ， 编 码 格式 的 选择 很 重要 。 如 果 使 用 Dreamweaver 开发 网 站 ， 那 么 可 以 选择 “编辑 ”/“ 首 
选 参 数 ”/“ 新 建文 档 ”/“ 默 认 编码 ”命令 设置 新 建文 件 的 编码 格式 。 这 样 就 不 必 再 为 创建 的 每 个 文件 的 编码 而 
担心 ， 因 为 它们 的 编码 格式 是 统一 的 。 
图 设计 过 程 


统一 Dreamweaver 创建 文件 编码 格式 的 方法 如 下 : 
(1) 打开 Dreamweaver 开发 工具 ， 选 择 “ 编 辑 ”/“ 首 选 参 数 ”命令 ， 弹 出 如 图 1.81 所 示 对 话 框 。 
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1.81 设置 文件 的 编码 格式 
(2) 在 其 中 指定 默认 编码 ， 最 后 单 击 “确定 ”按钮 。 


图 秘笈 心 法 


心 法 领悟 020: 在 Dreamweaver 中 设置 编码 。 

在 Dreamweaver 的 “首选 参数 ”设置 中 ， 不 但 可 以 设置 默认 编码 的 格式 ， 还 可 以 进行 其 他 设置 ， 如 CSS 样 
式 、 站 点 和 字体 等 。 

对 于 文件 编码 格式 的 选择 ， 强 烈 建议 读者 使 用 UTF-8， 因 为 这 样 可 以 与 国际 接轨 ， 如 果 单纯 地 使 用 GB2312 
编码 ， 那 么 一 旦 程序 要 更 改编 码 格式 ， 网 页 将 出 现 乱 码 。 如 果 使 用 UTF-8 编码 格式 ， 就 不 会 出 现任 何 问题 ， 因 
为 这 个 编码 格式 是 通用 的 。 

ee 
oh 中 级 .| 
实例 021 | 2 


四 实例 说 明 


实例 020 讲解 了 如 何在 Dreamweaver 中 设置 编码 格式 ， 下 面 介绍 一 下 Dreamweaver 的 具体 应 用 一 一 在 
Dreamweaver 中 创建 表格 。 运 行 结果 如 图 1.82 所 示 。 
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1.82 在 Dreamweaver 中 创建 表格 


图 关键 技术 


在 Dreamweaver 中 创建 表格 ， 有 两 种 方法 : 

第 一 种 ， 选 择 菜 单 栏 中 的 “插入 ”/“ 表 格 ”命令 ， 在 弹出 的 “表格 ”对 话 框 中 完成 表格 的 创建 操作 。 

第 二 种 ， 直 接 在 “常用 ”工具 栏 中 单 击 “ 表 格 ” 按 钮 国 ， 在 弹出 的 “表格 ”对 话 框 中 完成 表格 的 创建 操作 。 
图 设计 过 程 

在 Dreamweaver 中 创建 表格 的 操作 步骤 如 下 : 


(1) 打开 Dreamweaver 开发 工具 ， 选 择 “ 文 件 ”/“ 新 建 ” 命 令 ， 在 弹出 的 “新 建文 档 ” 对 话 框 中 创建 一 
个 “动态 页 ”/PHP 文件 ， 最 后 单 击 “ 创 建 ” 按 钮 ， 完 成 动态 PHP 文件 的 创建 ， 如 图 1.83 所 示 。 


图 1.83 创建 PHP 动态 文件 
(2) 如 图 1.84 所 示 ， 在 创建 的 Untitled-1 文件 中 ， 首 先 切换 到 设计 模式 下 ， 然 后 在 工具 栏 中 选择 “常用 ” 


| | an a | 


图 1.84 在 设计 模式 下 添加 表格 
(3) “表格 ”对 话 框 如 图 1.85 所 示 ， 在 其 中 可 以 设置 表格 的 行 数 、 列 数 、 表 格 宽度 、 边 框 粗细 、 单 元 格 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
边 距 和 单元 格 间距 等 。 设 置 完成 后 单 击 “ 确 定 ”按钮 ， 完 成 表格 的 创建 。 


图 1.85 “表格 ”对 话 框 
(4) 表格 创建 完成 后 ， 将 在 设计 界面 中 输出 如 图 1.86 所 示 的 内 容 。 
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1.86 创建 完成 的 表格 
(5) 选择 “文件 ” /“ 保 存 ” 命 令 ， 将 其 存储 于 Apache 服务 器 指定 的 文件 夹 下 ， 命 名 为 index.php。 运 行 结 
果 请 参考 实例 说 明 。 
图 秘笈 心 法 


心 法 领悟 021: 操作 表格 的 小 技巧 。 
在 图 1.86 所 示 的 表格 设计 界面 中 ， 表 格 处 于 选中 状态 时 ， 可 以 设置 其 属性 ， 包 括 行 数 、 列 数 、 表 格 宽度 、 
边框 粗细 、 单 元 格 边 距 、 单 元 格 间距 、 背 景 颜色 、 边 框 颜色 和 背景 图 像 等 。 


实 下 受 
实例 022 趣味 指数 : 让 丰 广 从 


图 实例 说 明 
实例 021 讲解 了 如 何在 Dreamweaver 中 创建 表格 ， 本 实例 将 讲解 如 何在 表格 中 插入 图 片 。 本 实例 的 运行 结 
果 如 图 1.87 所 示 。 


> 


1.87 表格 中 插入 宠物 图 片 


图 关键 技术 


在 Dreamweaver 中 ， 向 创建 的 表格 中 插入 图 片 时 ， 必 须 注意 图 片 的 存储 位 置 ， 最 好 的 方式 就 是 先 将 图 片 存 
储 到 实例 的 根 目录 下 ， 这 样 在 实例 运行 过 程 中 ， 不 会 因为 机 器 的 更 换 而 找 不 到 图 片 。 

如 果 没 有 将 图 片 存储 到 实例 的 根 目录 下 ， 在 执行 图 片 的 插入 操作 过 程 中 ， 将 给 出 一 个 如 图 1.88 所 示 的 提示 
信息 ， 提 示 是 否 将 图 片 存储 到 实例 的 根 目录 下 。 


图 1.88 插入 不 在 同一 驱动 器 上 的 文件 时 给 出 提示 


当 单 击 “ 是 ”按钮 时 ， 即 可 将 图 片 复制 到 实例 的 根 目 录 下 。 但 是 ， 这 种 做 法 有 一 个 弊端 ， 就 是 文件 的 存储 
没有 规范 性 。 试 想 一 下 ， 如 果 网 页 中 需要 插入 多 个 图 片 ， 程 序 的 根 目录 将 会 怎样 ? 所 以 最 好 的 方法 是 先 将 要 插 
入 的 图 片 存储 到 实例 根 目 录 下 的 一 个 指定 文件 夹 中 ， 这 样 做 比较 规范 ， 也 容易 管理 ， 一 般 都 将 这 个 图 片 存储 文 
件 夹 命名 为 images。 

如 果 在 图 1.88 的 提示 信息 中 ， 单 击 “ 否 ”按钮 虽然 图 片 仍然 可 以 插入 到 表格 中 ， 但 在 查看 网 页 代码 时 会 
发 现 ，img 标签 中 sre 属性 指定 的 图 片 文件 路 径 是 本 机 的 绝对 路 径 〈file:WEI/Program Files/9.gif) ， 在 本 机 中 仍 
然 可 以 运行 ， 但 要 将 本 实例 复制 到 其 他 机 器 上 运行 的 话 ， 在 指定 的 路 径 下 将 找 不 到 图 片 文 件 。 


图 设计 过 程 

在 Dreamweaver 中 创建 表格 的 操作 步骤 请 参考 实例 021， 这 里 不 再 歼 述 ， 下 面 介 绍 如 何在 创建 好 的 表格 中 
插入 图 片 。 

(1) 首先 ， 将 要 使 用 的 图 片 复制 到 本 实例 根 目 录 下 的 images 文件 夹 中 。 

(2) 将 光标 定位 到 要 插入 图 片 的 单元 格 中 ， 选 择 Dreamweaver 开发 工具 中 的 “插入 ”/“ 图 像 ”命令 ,在 
弹出 的 “选择 图 像 源 文件 ”对 话 框 中 选择 要 插入 的 图 片 ， 如 图 1.89 所 示 。 


EEC 
选取 文 上 名 全 三 文件 系统 
也 二 点 和 民生 


一 


EF 到 
Wm Bre | Wx 0 JIG /4 
0 ev IO 本 各 


也 


图 1.89 插入 图 片 
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(3) 确定 要 插入 的 图 片 之 后 ， 单 击 “确定 ”按钮 ， 即 完成 图 片 的 插入 操作 。 
(4) 保存 文件 ， 在 正 浏览 器 中 输入 网 址 ， 即 可 运行 本 实例 ， 运 行 结果 请 参看 实例 说 明 。 


图 秘笈 心 法 


心 法 领悟 022: 操作 Dreamweaver 小 技巧 。 
在 Dreamweaver 的 设计 模式 下 ， 当 选中 插入 的 图 片 时 ， 在 开发 工具 的 下 方 将 出 现 图 像 的 属性 操作 界面 ， 
如 图 1.90 所 示 。 通 过 这 个 属性 操作 界面 可 以 设置 图 像 的 宽度 、 高 度 、 链 接 以 及 是 否 添 加 地 图 等 。 


图 售 ，2r7 3 0 re S55 nl S| 8 
高 本 链 按 DD 加 本 到 OA 

[DJ BE | ”到 到 到 

R DIOM x*ruwl i) ER 本。 


图 1.90 图 像 的 属性 操作 界面 


起 味 指数 : 页 庚 页 窜 | 


实例 023 


力 实例 说 明 

本 实例 讲解 如 何在 Dreamweaver 中 创建 表单 。 表 单 是 网 站 与 客户 沟通 的 一 座 桥梁 ， 通 过 它 可 以 直接 将 客户 
的 信息 反馈 给 网 站 的 管理 者 ， 达 到 企业 与 网 站 浏览 者 更 好 的 交互 效果 。 在 本 实例 中 将 对 如 何在 Dreamweaver 中 
创建 表单 进行 详细 讲解 ， 实 例 的 运行 结果 如 图 1.91 所 示 。 


文件 中 铀 盖 G) 查看 0 收藏 人 ) 工具 T) 帮助 0 E32 
BED [mts io 0 0 tar/o1/ne3 PISE Rm 


[ 陋 二 入 不 硬 下 人 信和 ” 司 
简介 : 
到 


人 1 他: | 万 并 厂 全 三 文学 


图 书 过 库 : | PHP 开 发 实战 本 内 本 
ees | 
周 宁 | [| Bis 


图 1.91 创建 表单 元 素 


力 关键 技术 


在 Dreamweaver 中 创建 表单 ， 首 先 要 在 工具 栏 中 选择 “表单 ”选项 ， 然 后 就 可 以 通过 不 同 的 按钮 创建 不 同 
的 表单 元 素 ， 其 中 每 个 按钮 对 应 的 功能 如 表 1.1 所 示 。 
表 1.1 Dreamweaver 中 的 表单 元 素 
说 明 
<form name="form?2" method="post" action=""></form> 
name: 表单 的 名 称 


method: 表单 提交 的 方法 ， 包 括 POST 和 GET 方法 
action: 表单 提交 的 路 径 


像 


名 称 


文本 字段 
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<input type="text" name="textfield"> 
type: 应 用 表单 的 类 型 
name: 文本 框 的 名 称 


隐藏 域 


<input type="hidden" name="ID" value=""> 
type: 表单 的 类 型 ， 其 中 的 hidden 表示 隐藏 域 
name: 隐藏 域 的 名 称 ， 可 以 自己 定义 

Value: 隐藏 域 的 值 ， 可 以 填写 隐藏 域 的 默认 值 


四 


文本 区 域 


复 选 框 


单 选 按钮 


单 选 按钮 组 


列表 \ 菜 单 


<textarea name="" cols="" IOWS="" id=""></textarea> 
<textarea>...</textarea>: 文本 域 的 标记 
name: 文本 域 的 名 称 ， 例 如 其 中 的 test 
cols: 表示 文本 域 字符 的 宽度 
rows: 表示 有 多 少 行 字符 
初始 值 在 <textarea></textarea> 标 记 之 间 进 行 输入 ， 例 如 其 中 的 “欢迎 大 家 访问 我 们 的 论坛 ” 
<input type="checkbox" name="checkbox" value=" 体 育 "> 
type: 表单 的 类 型 ， 其 中 的 checkbox 表示 复 选 框 
name: 复 选 框 的 名 称 ， 例 如 其 中 的 checkbox 
value: 复 选 框 提交 的 值 ， 例 如 其 中 的 “体育 ” 
checked: 如 果 希 望 预 先 为 用 户 选中 某 些 选项 ， 可 以 为 这 些 选项 加 上 checked 参数 
disabled: 如果 希望 某 一 个 选项 失效 ， 可 以 加 上 disabled 参数 
<input type="radio" name="radiobutton" value="radiobutton" checked="checked" /> 男 
<input type="radio" name="radiobutton" value="radiobutton" /> 女 
<input type="radio" name="RadioGroupl" value=" 单 选 " 放 单 选 
<input type="radio" name="RadioGroupl" value=" 单 选 " /> 单 选 
<select name="select2"> 
<option selected="selected"> 默 认 值 </option> 
<option value=" 对 应 值 1"> 列 表 值 1</option> 
<option value=" 对 应 值 2"> 列 表 值 2</option> 


</select> 
name: 指 该 <select> 组 件 的 名 称 
option: 提供 给 用 户 选择 的 项 目 ， 其 中 的 value 是 该 选项 所 代表 对 应 的 选择 值 ， 可 以 省 略 


回 


跳 转 菜单 


<select name="menul" onchange="MM _jumpMenu(parent .this.0)"> 
<option>unnamed1</option> 
</select> 


跳 转 菜 单 ， 通 过 表单 实现 指定 网 址 之 间 的 跳 转 


图 像 域 


<input type="image" name="imageField" src="images/QQ.gif" > 在 表单 中 插入 图 片 


文件 域 


<input type="file" name="file" /> 完成 文件 的 提交 


口 回回 


按钮 


<input type="submit" name="Submit" value=" 提 交 " /> 创建 的 提交 按钮 ,如 果 type 的 值 为 button， 
那么 它 表示 一 个 普通 的 按钮 ， 不 具备 提交 的 功能 
<input type="reset" name="Submit2" value=" 重 置 " /> 创建 的 重 置 按钮 


标签 


<labe 上 > 标签 </label> 


口 国 


字段 集 


<fieldset><legend> 字 段 集 </legend></fieldset> 
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图 设计 过 程 
在 Dreamweaver 中 创建 表单 的 操作 步骤 如 下 : 


(1) 新 建 一 个 动态 PHP 文件 ， 切 换 到 设计 模式 下 。 
(2) 在 工具 栏 中 选择 “表单 ”选项 ， 如 图 1.92 所 示 。 


EDEI-LTYaJ lallalallelele)lea 
图 1.92 选择 表单 工具 
(3) 添加 一 个 form 表单 ， 如 图 1.93 所 示 。 
Egaaagaaaasaasas 

图 1.93 添加 表单 

(4) 根据 实际 需要 ， 添 加 不 同 的 表单 元 素 ， 并 设置 相应 的 名 称 和 值 ， 如 图 1.94 所 示 。 

EL | | 
图 1.94 添加 表单 元 素 

最 终 创建 的 表单 元 素 设计 效果 如 图 1.95 所 示 。 


:| 网 音乐 厂 体育 三 文学 
:|C 男 CC 女 
C PHP 


:| C Jama 


C vB 


1.95 表单 元 素 的 设计 效果 
国 秘笈 心 法 


心 法 领悟 023: 通过 表单 传 值 时 的 注意 事项 。 

在 通过 表单 中 的 元 素 传递 值 的 时 候 ， 一 定 要 正确 地 书写 表单 元 素 的 名 称 ， 其 中 不 应 该 有 空格 存在 ; 在 获取 
表单 元 素 的 值 时 ， 表 单元 素 的 名 称 一 定 要 与 form 中 设置 的 名 称 相同 ， 同 时 还 要 注意 大 小 写 的 统一 ， 否 则 将 不 能 
获取 到 表单 元 素 的 值 。 


实 建 和 附加 CSS 样式 了 | 
国 实例 说 明 


本 实例 讲解 如 何在 Dreamweaver 中 创建 和 附加 CSS 样式 。 通过 CSS 能 够 更 好 地 对 网 页 中 的 表格 、 文本 和 图 
像 的 样式 进行 控制 ， 并 且 使 其 更 易于 维护 和 更 新 。 本 实例 的 运行 结果 如 图 1.96 所 示 。 
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编程 词典 言传 语 总 结 


二 计生 可 请 和 的 “ 亲 和 守 和 典 ”” 具 各 海量 的 到 和 资源 * 天助 您 解 在 学 习 办 
程 香 言 中 退 到 的 问题 - 


(2) 碟 程 者 的 良 病 益 友 - 为 起 的 插 习 提供 完 问 的 皖 习 方 案 ， 失意 提供 理论 和 实践 相 结合 
的 机 会 ( 字 习 方法 、 实 例 、 实 跨 竺 习 ) 


Cd 
可 以 作为 参考 ， 也 可 以 直接 使 用 - 《 方案 、 程 序 》 


(4) 完美 的 售后 服务 和 交互 方式 - 9、 电 话 、 FRAIL 


1.96 ”Dreamweaver 中 创建 和 附加 CSS 样式 


图 关键 技术 


在 Dreamweaver 中 创建 CSS 样式 ， 必 须 明确 新 建 CSS 样式 的 规则 ， 如 图 1.97 所 示 。 


新 建 css 


we c Ca 


图 1.97 新建 CSS 规则 


如 果 选 中 “新 建 样式 表 文 件 ) ” 单 选 按 钮 ， 那 么 定义 的 CSS 存储 于 指定 的 文件 夹 下 ; 如 果 选 中 “ 仅 对 该 
文档 ” 单 选 按钮 ， 那 么 定义 的 CSS 存储 于 该 文件 中 。 

如 果 只 是 对 单独 的 某 个 文件 进行 操作 ， 建 议 将 CSS 定义 到 当前 文件 中 ， 但 是 ， 如 果 是 在 网 站 中 应 用 CSS， 
那么 应 该 将 CSS 样式 定义 到 单独 的 文件 中 ， 并 且 以 类 的 形式 进行 定义 ， 因 为 这 样 便于 对 CSS 样式 的 修改 ， 使 网 
站 的 样式 更 加 统一 ， 而 且 可 以 避免 代码 的 元 余 。 

图 设计 过 程 

创建 一 个 名 称 为 styles 的 样式 ， 将 其 定义 到 新 建 样式 表 中 ， 使 用 类 的 形式 进行 定义 ， 其 具体 的 操作 步 又 
如 下 : 

(1) 在 Dreamweaver 的 设计 模式 下 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “CSS 样式 ”/“ 新 建 ” 命 令 ， 在 弹出 
的 “新 建 CSS 规则 ”对 话 框 中 定义 CSS 样式 的 规则 ， 如 图 1.98 所 示 。 

(2) CSS 样式 的 规则 定义 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 弹 出 “保存 样式 表 文件 为 ”对 话 框 ， 定 义 CSS 样 
式 文件 的 存储 位 置 ， 如 图 1.99 所 示 。 


选取 立 件 画 自 Se 让 点 和 服务 器 
RED [ce OF 
新 建 css 规则 划 
毕 近 器 闫 型。 个 类 可 应 用 于 任何 标签 ) 他) 文件 各 WD; eles 保存 (8) 
内 me 守 O 地 油 人 DR ec | 
5 可 | 
[CR mo 对 
二 对 蛮 交 格 定义 中 在 隐 扶 认 的 洲 返 柜 于 a 
1.98 定义 CSS 样式 的 规则 1.99 定义 CSS 样式 表 的 存储 位 置 


(3) 确定 存储 位 置 和 名 称 后 ， 单 击 “ 保 存 ” 按 钮 ， 将 弹出 styles 样式 具体 的 规则 定义 对 话 框 ， 如 图 1.100 
所 示 。 在 其 中 ， 可 以 根据 “分 类 ”， 对 类 型 、 背 景 、 区 块 、 方 框 、 边 框 、 列 表 、 定 位 和 扩展 分 别 进行 定义 ， 单 
击 “ 确 定 ”按钮 ，styles 样式 创建 完成 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


le， 的 CSS 规 宇 咏 ( 在 Stylescss 中 
2 Ee 
启 放 人 外; 刁 
a A 
| wm:"— 可 
Re | Ce Ee | 
亿 册 四- 厂 下 0D OF 

厂 起 大 四 

厂 最 际 二 加 

[0 

[是 工 

CE ww | 四 日 | wm 


图 1.100 定义 styles 样式 的 规则 


(4) 在 Dreamweaver 的 设计 模式 下 ， 选 中 被 操作 的 内 容 ， 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “CSS 样式 ” 命 
令 ， 即 可 选择 指定 的 样式 文件 ， 如 图 1.101 所 示 。 


篇 程 词典 言传 语 总 结 : 
上 | 向 本 69 而 “新 和 于 下 ”下 者 向 到 到 表 大 末了 和 犁 天 在 于 可 转 各 本 下 天 到 的 有 


ES | 
EE 下 证 页 面 、 丰 到 有 胃 讶 砍 害 。 可 以 作为 吉村 


1.101 ”应 用 定义 的 CSS 样式 


妈 9 技巧 : 附加 CSS 样式 文件 。 在 Dreamweaver 的 设计 模式 下 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “CSS 样式 ”/ 
“附加 样式 表 ” 命 令 ， 在 弹出 的 “链接 外 部 样式 表 ” 对 话 框 中 可 选择 定义 在 指定 文件 天 下 的 CSS 样 
式 文件 。 如 果 选 择 “ 链 接 ”, 则 直接 通过 link 标签 链接 到 CSS 样式 文件 ;如 果 选 择 导 入 , 则 通过 @import 

url 导入 指定 的 CSS 文件。 确定 附加 的 CSS 样式 文件 后 ， 单 击 “ 确 定 ” 按 钮 。 


国 秘 稚 心 法 


心 法 领悟 024: 在 Dreamweaver 中 创建 CSS 样式 的 相关 说 明 。 


在 Dreamweaver 中 创建 的 CSS 样式 , 可 以 在 代码 模式 下 对 其 进行 修改 , 也 可 以 在 设计 模式 下 对 其 进行 修改 ， 
如 图 1.102 所 示 。 


图 1.102 在 设计 模式 下 操作 CSS 样式 
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实例 025 


力 实例 说 明 


在 Dreamweaver 中 不 但 可 以 创建 表格 、 表 单 或 者 CSS 样式 等 内 容 ， 而 且 可 以 通过 行为 ， 实 现 一 些 特殊 的 
功能 。 例 如 ， 在 本 实例 中 定义 一 个 “弹出 信息 ”行为 ， 当 用 户 单 击 指定 的 图 片 时 ， 将 弹出 一 个 提示 对 话 框 ， 


如 图 1.103 所 示 。 
;证 请 的 个 人 知客 


雯 用 FP 汪 骨 


会 员 名 称 : | 


和 介 : | 
十 人 要好 
性 别 : 


[3 
ET 


Copyright 1999-2010 吉林 省 明 日 科技 有 限 公司 


图 1.103 ”通过 Dreamweaver 直接 创建 的 弹出 信息 


图 关键 技术 


在 Dreamweaver 中 控制 弹出 信息 的 原理 是 自动 创建 JavaScript 脚本 文件 ， 定 义 方法 ， 然 后 通过 onclick 调用 
脚本 中 的 方法 ， 完 成 当 鼠 标 单 击 指定 的 内 容 时 弹出 信息 。 


JavaScript 脚本 中 定义 的 方法 如 下 : 

‘<script type="text/JavaScript"> 

<!-- 

function MM_popupMsg(msg) { //v1.0 
alert(msg); 


在 表单 的 图 像 域 中 ， 通 过 onclick 事件 完成 对 脚本 文件 方法 的 调用 ， 其 代码 如 下 : 
<input name="imageField" type="image" onclick="MM_popupMsg(' 请 输入 完整 的 注册 信息 )" src="images/09jpg" /> 
图 设计 过 程 
在 Dreamweaver 中 添加 “弹出 信息 ”行为 的 操作 步骤 如 下 : 
(1) 通过 Dreamweaver 新 建 一 个 index.php 文件 ， 创 建 一 个 用 户 注册 页 面 。 
(2) 在 Dreamweaver 的 设计 模式 下 , 选择 用 户 注册 的 图 像 域 , 然后 选择 “窗口 /行为 ”命令 , 在 Dreamweaver 
操作 界面 的 右 侧 将 弹出 如 图 1.104 所 示 的 内 容 。 
(3) 在 图 1.104 所 示 的 界面 中 , 单 击 到 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “弹出 信息 ”选项 , 将 弹出 如 图 1.105 
所 示 的 “弹出 信息 ”对 话 框 ， 在 “消息 ”文本 框 中 定义 弹出 信息 的 内 容 ， 最 后 单 击 “确定 ”按钮 ， 弹 出 信息 的 


栈 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


行为 创建 完毕 。 
a 司 CJ] 
避 bk 
图 1.104 行为 控制 面板 图 1.105 编辑 弹出 信息 


心 法 领悟 025: 在 Dreamweaver 中 实现 一 些 JavaScript 功能 。 


在 Dreamweaver 中 , “弹出 信息 ”只 是 众多 行为 中 的 一 个 ， 还 可 以 通过 “窗口 ”中 的 行为 实现 很 多 的 功能 ， 
如 图 1.106 所 示 。 


实例 026 趣味 指数 : 址 走 址 窜 


力 实例 说 明 


本 实例 将 介绍 Dreamweaver 中 行为 的 另 一 种 功能 一 一 控制 打开 浏览 器 的 窗口 。 通 过 该 功能 可 以 对 打开 的 浏 
览 器 窗口 进行 设置 ， 包 括 窗 口 的 高 度 、 宽 度 以 及 是 否 包含 导航 工具 栏 、 地 址 工具 栏 和 菜单 栏 等 ， 本 实例 的 运行 
结果 如 图 1.107 所 示 。 


< 控制 浏 寅 要 打开 全 口 -microswEE EREEEGGE 


Er ety: t/t.0.0.1 fae /0/02L/ inde ok ph | | 


PR 


| 多 用 P 渤 册 
52: 
前 仙 : | 于 十 入 态 的 下 人 信息 四 


。 个 人 过 好 : 网 音 和 张 厂 体育 厂 立 学 
| 性 淖 3 个 男 全 女 


语言 夫 择 - C Jove 


”图书 迁 择 : |PHF 开 发 支 此 主 具 可 


| 过 ET 
1.107 Dreamweaver 控制 浏览 器 的 窗口 
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图 关键 技术 


控制 打开 浏览 器 的 窗口 同样 是 Dreamweaver 中 行为 的 一 种 功能 , 通过 该 功能 可 以 控制 网 页 窗口 的 打开 模式 。 
例如 ， 网 页 窗口 中 导航 条 的 使 用 、 滚 动 条 的 使 用 、 地 址 工具 栏 的 应 用 以 及 网 页 窗口 的 大 小 等 。 
行为 中 “打开 浏览 器 窗口 ”的 操作 界面 如 图 1.108 所 示 。 


RL | 
om Fr ae 0 —mw | 


图 1.108 “打开 浏览 器 窗口 ”对 话 框 
设计 过 程 
在 Dreamweaver 中 添加 “打开 浏览 器 窗口 ”行为 的 操作 步骤 与 添加 “弹出 信息 ”行为 是 相同 的 ， 唯 一 的 区 
别 是 在 单 击 至 按钮 时 ， 在 弹出 的 下 拉 菜 单 中 选择 “打开 浏览 器 窗口 ”命令 ， 将 弹出 如 图 1.108 所 示 的 “打开 浏览 
器 窗口 ”对 话 框 。 
秘笈 心 ; 
心 法 领悟 026: 在 Dreamweaver 中 屏蔽 标准 按钮 。 


通过 “打开 浏览 器 窗口 ”行为 ， 可 以 屏蔽 浏览 器 窗口 中 的 标准 按钮 ， 这 个 功能 在 某 些 程序 中 是 非常 有 用 的 。 
例如 ， 在 一 些 需要 屏蔽 刷新 功能 的 网 页 中 ， 通 过 “打开 浏览 器 窗口 ”行为 来 实现 是 比较 不 错 的 方法 。 


趣味 指数 : oodotodl 
用 实例 说 明 

本 实例 讲解 如 何在 Dreamweaver 中 创建 站 点 ， 从 而 不 必 在 下 浏览 器 中 输入 地 址 ， 只 需 按 F12 键 , 即 可 完成 
对 所 创建 程序 的 浏览 操作 。 


图 关键 技术 


在 Dreamweaver 中 创建 站 点 和 配置 测试 服务 器 时 ,一定 要 注意 将 本 地 的 HITP 地 址 与 测试 服务 器 中 的 URL 
前 缀 统一 ， 即 都 指定 到 站 点 的 根 目录 下 。 例 如 ， 指 定 HITP 的 地 址 是 http://localhost/mr/01/， 那 么 测试 服务 器 的 
URL 前 级 也 必须 是 http://localhost/mr/01/ 或 者 http://127.0.0.1/mr/01/。 


图 设计 过 程 

在 Dreamweaver 中 创建 站 点 的 操作 步骤 如 下 : 

(1) 打开 Dreamweaver 开发 工具 ， 选 择 菜单 栏 中 的 “站 点 ”/“ 新 建站 点 ”命令 ， 在 弹出 的 如 图 1.109 所 示 
对 话 框 中 添加 站 点 名 称 、 设 置 本 地 根 文件 夹 、 链 接 相 对 于 “站 点 根 目录 ”、 设 置 HITP 地 址 。 


(2) 选择 左 侧 的 “测试 服务 器 ”选项 ,进入 如 图 1.110 所 示 的 “测试 服务 器 ”对 话 框 ,选择 服务 器 模型 PHP 
MySQL， 访 问 为 “本 地 /网 络 ”， 测 试 服务 器 文件 夹 为 F\PkhPHP\www\，URL 前 组 为 http://localhost/， 最 后 单 
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击 “ 确 定 ” 按 钮 。 


万 新 不 地 文 补 列 表册 
默认 图 像 立 件 到 人 已 


测试 报名 器 
脏 接 相对 于 ; 信玄 档 罩 ) 人 站 点 朴 目 录 E) 
7 PEP? Te | 
和 ago Ev 
5X 关 ia 口 
区 分 大 小写 的 猎 接 ; 厂 使 用 区 分 大 十 写 的 哇 按 梯 查 0) 厂 目 动 得 新 测试 娘 六 列表 呈 ) 
生存 ; 厂 局 用 经 存 E) 最 mr 
CE | | Ci wy | ww | 
图 1.109 定义 mr 站 点 图 1.110 配置 测试 服务 器 


(3) mr 站 点 和 测试 服务 器 设置 完毕 后 ， 就 可 以 在 Dreamweaver 下 直接 使 用 F12 键 来 浏览 程序 了 。 
心 法 领悟 027: 在 Dreamweaver 中 创建 站 点 的 注意 事项 。 


在 Dreamweaver 中 创建 站 点 和 配置 测试 服务 器 时 , 如 果 本 地 的 HTTP 地 址 与 测试 服务 器 中 的 URL 前 级 不 统 
一 ， 那 么 就 不 能 够 通过 F12 键 直接 浏览 程序 。 


过 开发 第 1 个 PHP 程序 中 级 | 
实例 028 趣味 指数 : holed 
力 实例 说 明 


前 面 实例 讲 解 了 Dreamweaver 自身 功能 的 运用 ,在 本 实例 中 应 用 Dreamweaver 开发 一 个 最 简单 的 PHP 程序 ， 
即 输 出 一 段 欢迎 信息 ， 其 目的 一 是 了 解 PHP 的 语法 规则 ， 二 是 熟悉 Dreamweaver 开发 工具 的 使 用 。 运 行 结果 如 
图 1.111 所 示 。 


济 第 一 个 PiF 程 序 ~ Wicrosoft Interaedzo700 


文件 @) 编辑 EE) 查看 WW) 收藏 和 ) 工具 上 竹 > rr 
地 址 甸 | 智 http: //127.0.0. 1/mr/01/028/ 司 BE ED » 


| wim 和 pa 办! FE 
BE 厂矿 于 


图 1.111 第 1 个 PHP 程序 


图 关键 技术 


必须 将 通过 Dreamweaver 开发 工具 编写 的 PHP 脚本 ， 存 储 到 PHP 开发 环境 指定 的 服务 器 文件 夹 下 才 可 


力 设计 过 程 
(1) 打开 Dreamweaver 开发 工具 ， 新 建 一 个 PHP 项 目 ， 如 图 1.112 所 示 。 
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图 1.113 新 的 PHP 项 目 文件 


(3) 在 图 1.113 所 示 的 文件 中 , 首先 定义 文件 的 标题 <title> 第 一 个 PHP 程序 </title>, 然后 编写 PHP 代码 ， 
其 代码 如 下 : 
< 


php 
echo "欢迎 进入 PHP 的 世界 ! “ 
> 


PHP 代码 分 析 : 


“<?php” 和 “?>” 是 PHP 的 标记 对 。 在 这 对 标记 中 的 所 有 代码 都 被 当 作 PHP 代码 来 处 理 。 
echo 是 PHP 中 的 输出 语句 ， 与 ASP 中 的 response.write、JSP 中 的 out.print 含义 相同 ， 输 出 字符 串 或 
者 变量 值 。 每 行 代码 都 以 分 号 “;” 结 尾 。 


(4) 保存 文件 ， 选 择 图 1.113 中 的 “文件 ”/“ 另 存 为 ”命令 ， 将 编写 的 文件 保存 在 站 点 的 根 目录 www 文 
件 夹 中 ， 并 命名 为 testphp， 最 后 单 击 “ 保 存 ” 按 钮 ， 如 图 1.114 所 示 。 
力 秘笈 心 法 
心 法 领悟 028: 运行 程序 的 两 种 方法 。 
程序 的 运行 有 两 种 方法 : 第 一 种 ， 直 接 在 Dreamweaver 开发 工具 中 按 F12 键 运行 程序 ; 第 二 种 , 在 正 浏 览 
器 的 地 址 栏 中 输入 http://127.0.0.1/test.php。 程 序 运行 的 前 提 是 必须 将 程序 存储 到 服务 器 指定 的 文件 夹 中 。 
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EE 
口 生 已 四 - 


图 1.114 保存 编写 的 PHP 文件 


1.7 Zend Studio 开发 工具 


Zend Studio 是 目前 比较 流行 的 PHP 开发 工具 ， 襄 括 了 编辑 、 调 试 、 配 置 PHP 程序 所 需要 的 客户 及 服务 器 
组 件 ， 尤 其 是 功能 齐全 的 调试 功能 ， 让 PHP 错误 不 再 棘手 。 

Zend Studio 也 有 不 足 之 处 ， 一 是 运行 速度 慢 ; 二 是 没有 Dreamweaver 的 界面 设计 功能 ， 只 能 通过 浏览 器 来 
浏览 页 面 设计 效果 ; 三 是 其 是 一 款 收费 软件 (但 可 以 下 载 试用 版 )， 下 载 地 址 为 http://www.zend.conystore/ 
products/zend-studio.php 。 


二 中 级 
图 实例 说 明 


在 应 用 Zend Studio for Eclipse 之 前 ， 我 们 有 必要 介绍 一 下 它 的 安装 步骤 ， 因 为 只 有 正确 地 完成 安装 ， 才 能 
够 顺利 地 应 用 。 


力 关键 技术 


在 安装 Zend Studio for Eclipse 的 过 程 中 , 关键 是 安装 内 容 的 选择 、 安装 位 置 的 选择 和 定义 Zend 支持 的 文件 
格式 ， 这 是 在 安装 过 程 中 必须 注意 的 内 容 。 


图 设计 过 程 
(1) 运行 安装 文件 ， 进 行 安装 准备 工作 ， 如 图 1.115 所 示 。 


CC 


[C}2002.2006 Macrovison Europe Léand/or Macowsion Corporstion 


图 1.115 安装 Zend Studio for Eclipse 的 准备 工作 
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(2) 进入 安装 界面 ， 如 图 1.116 所 示 ， 单 击 Next 按钮 。 
(3) 进入 阅读 服务 器 条 款 对 话 框 ， 选 择 同意 ， 如 图 1.117 SR 单 击 Next 按钮 。 


ee 
Stdio for Eclipse 


lekine Nod nutono croceodts a nosereon Fycu yat 
hange something on 3 prevous seroen, olectne Pravous’ curnn 
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图 1.116 开始 进行 安装 图 1.117 阅读 服务 条 款 


(4) 在 选择 安装 内 容 对 话 框 中 包括 一 个 Zend 浏览 器 和 Zend Studio， 两 项 全 部 选中 ， 如 图 1.118 所 示 。 单 
击 Next 按钮 ， 进 入 下 一 步 。 

(5) 在 进入 的 对 话 框 中 设置 文件 的 安装 目录 ， 用 户 可 以 任意 指定 安装 位 置 ， 确 定 后 单 击 Next 按钮 进行 下 
一 步 ， 如 图 1.119 所 示 。 


FP Quck Loynen oatar 


oebugget and cronler and robuat sooe 5omp en 
PHP canatmuets ne weli an HTML 


1.118 选择 安装 内 容 1.119 设置 工具 安装 位 置 


(6) 在 进入 的 定义 Zend 支持 的 文件 格式 对 话 框 中 ， 全 部 选中 ， 如 图 1.120 所 示 。 
(7) 确认 安装 信息 ， 如 图 1.121 所 示 ， 单 击 Install 按钮 开始 进行 安装 。 


Please review the follewing infermation 


Proguct Name: 
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图 1.120 定义 Zend 支持 的 文件 格式 1.121 确认 安装 信息 


of 
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(8) 安装 进行 中 ， 如 图 1.122 所 示 。 
(9) 安装 完成 ， 单 击 Done 按钮 ， 如 图 1.123 所 示 。 


Installing Zend Studio for Eclipse -6.1.1 
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图 1.122 Zend 安装 进行 中 图 1.123 ”安装 成 功 
这 就 是 Zend Studio for Eclipse 的 安装 ， 过 程 非常 简单 ， 但 是 等 待 的 时 间 较 长 。 
图 秘笈 心 法 
心 法 领悟 029: 选择 工作 空间 。 


运行 Zend Studio for Eclipse， 可 以 选择 File/Switch Workspace 命令 来 选择 工作 的 空间 ， 或 者 重新 创建 工作 
空间 ， 如 图 1.124 所 示 。 


) workspace Launcher x| 


Select a workspace 


Zend Studio stores your projects In a folder called a workspace. 
Choose a workspace folder to use for this session, 


Workspace: [BE -| Browse | 
* Copy Settings 
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图 1.124 创建 工作 空间 


中 级 | 
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实例 030 


力 实例 说 明 


本 实例 介绍 如 何 通过 Zend Studio 创建 PHP 项 目 。 在 本 项 目 中 创建 一 个 PHP 文件 ， 通 过 phpinfo0 函 数 输出 
PHP 的 配置 信息 ， 其 运行 结果 如 图 1.125 所 示 。 


国 关键 技术 


通过 Zend Studio 编写 PHP 程序 ， 首 先 要 选择 正确 的 工作 空间 ， 如 果 工 作 空间 选择 不 正确 ， 那 么 PHP 的 程 
序 就 无 法 运行 。 


> 
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图 1.125 运行 程序 


用 设计 过 程 


(1) 运行 Zend Studio， 首 先进 入 Zend Studio 的 欢迎 页 面 ， 如 图 1.126 所 示 。 


Welcome to Zend Studio for Eclipse 僵 = 


5 Ways to Get started with zend studio for 
Eclipse 


7 Create a zend Eramaewtork Example Working mkh tho profler 
projoct Working with Rotactoring 
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Working with cvs 
Working with SYN 


1.126 进入 Zend Studio 欢迎 页 面 


(2) 选择 “文件 ”/“ 切 换 工作 空间 ”/“ 其 他 ”命令 ,设置 工作 空间 ， 将 项 目 保存 在 指定 名 称 的 文件 夹 中 ， 
如 图 1.127 所 示 ， 将 F:\PkKhPHPWwww 文件 夹 作 为 工作 空间 。 


先锋 工作 室 间 
下 全 让 各 力 基 工作 富 的 区 件 关 中 


1.127 选择 工作 空间 
(3) 接 下 来 进入 Zend Studio 的 工作 台中 ， 如 图 1.128 所 示 。 
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图 1.128 ”Zend Studio 的 工作 台 
(4) 创建 一 个 PHP 项 目 。 选择“ 文件 ”/“ 新 建 ”/PHP Project 命令 ， 创 建 一 个 PHP 项 目 ， 如 图 1.129 所 示 。 


图 1.129 创建 PHP 项 目 


(5) 进入 新 项 目 创建 窗口 中 ， 在 该 窗口 中 设置 项 目 名 称 为 01; 指定 项 目 文件 存储 位 置 ， 这 里 使 用 默认 值 ; 


1.130 新建 项 目 
(6) 在 项 目 01 中 创建 PHP 文件， 如 图 1.131 所 示 。 


%® 
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1.131 创建 PHP 文件 


在 图 1.129 所 示 的 操作 步 又 中 ， 不 但 可 以 创建 PHP 文件 ， 还 可 以 创建 HTML、CSS、JavaScript 和 XML 文 
件 等 ， 具 体 可 以 根据 程序 的 实际 情况 进行 创建 。 
(7) 进入 文件 创建 窗口 ， 定 义 文件 名 称 ， 最 后 单 击 Finish 按钮 ， 如 图 1.132 所 示 。 


图 1.132 创建 index.php 文件 
(8) 文件 创建 成 功 后 ， 就 可 以 在 编辑 区 中 编辑 文件 的 内 容 ， 如 图 1.133 所 示 。 


fer Religie 


图 1.133 编辑 PHP 代码 
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如 图 1.133 所 示 ，Zend Studio for Eclipse 工具 最 大 的 优点 就 是 代码 提示 功能 ， 它 可 以 在 用 户 输入 部 分 PHP 
脚本 语言 时 ， 给 出 相关 PHP 脚本 语言 的 提示 供 选择 。 这 里 应 用 phpinfo0 函 数 获取 PHP 的 相关 配置 信息 。 
(9) 编辑 完成 后 ， 保 存 该 文件 ， 单 击 殉 按 钮 ， 运 行程 序 ， 运 行 结果 请 参看 实例 说 明 。 


心 法 领悟 030: Zend Studio 对 Zend Framework 框架 的 支持 。 


通过 Zend Studio 不 但 可 以 创建 PHP 项 目 ， 而 且 可 以 直接 生成 Zend Framework 框架 ， 开 发 者 不 必 再 为 搭建 
Zend Framework 框架 而 头疼 。 


实例 031 趣味 指教 : 请 请 请 容 | 
图 实例 说 明 


在 Zend Studio 中 同样 可 以 控制 创建 项 目 、 文 件 的 编码 格式 ， 至 于 编码 格式 选择 的 重要 性 这 里 不 再 浆 述 。 下 
面 介绍 如 何在 Zend Studio 中 设置 项 目 、 文 件 的 编码 格式 。 如 果 通 过 Zend Studio 打开 一 个 编码 格式 不 匹配 的 文 
件 ， 输 出 结果 如 图 1.134 所 示 。 


!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transicional//EN”" 加 
2 <html xmlns="http://www.w3. org/1999/xhtmi"> 
Si<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf- 
5 <title>Dreamweaver 银 y 起 娴 届 ” 错 儿 寺 窜 [给 权 肥 </tic1e> 
6 <link href="css/styles.css" rel="stylesheet" type="text/css" /> 
7 日 <acripr type="text/Javascript"> 
8 <!-- 
9 function NM popupMsg(msg) { //v1.0 
alert (msg); 
} 
2 //--> 
</script> 


</head> 
4 


图 1.134 ”编码 格式 不 正确 导致 乱码 


力 关键 技术 


在 Zend Studio 中 设置 项 目 、 文 件 的 编码 格式 ， 关 键 是 从 根本 着 手 ， 也 就 是 说 要 控制 一 个 项 目 中 文件 的 编码 
格式 ， 只 要 项 目 本 身 的 编码 格式 确立 ， 那 么 创建 的 文件 格式 自然 是 与 项 目 相同 的 。 


图 设计 过 程 

(1) 在 Zend Studio 中 要 设置 项 目的 编码 格式 ， 首 先 就 要 创建 一 个 项 目 。 有 关 项 目 创 建 的 具体 步骤 请 参看 
实例 030， 这 里 不 再 效 述 。 

(2) 项 目 创建 成 功 后 , 选中 创建 的 项 目 , 右 击 , 在 弹出 的 快捷 菜单 中 选择 Properties 命令 , 弹出 如 图 1.135 
所 示 的 窗口 。 

(3) 在 该 窗口 中 选中 Other 单 选 按 钮 ， 在 其 下 拉 列 表 中 选择 指定 的 编码 格式 ， 最 后 单 击 OK 按钮 ， 项 目 编 
码 格式 即 设置 完成 。 
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由 -Code Style Dype: Project 
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Text file encoding 
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图 1.135 设置 项 目的 编码 格式 


国 秘笈 心 法 

心 法 领悟 031: 在 Zend Studio 中 修改 编码 格式 。 

在 实例 说 明 中 我 们 曾 看 到 一 个 编码 格式 不 匹配 的 文件 打开 的 效果 ， 那 么 如 何 对 这 个 文件 的 编码 格式 进行 修 
改 呢 ? 

首先 ， 打 开 编 码 格式 不 匹配 的 文件 。 然 后 单 击 Edit 按钮 ， 在 弹出 的 菜单 中 选择 Set Encoding 命令 ， 将 弹出 
如 图 1.136 所 示 的 对 话 框 , 在 这 个 对 话 框 中 选中 Other 单 选 按 钮 , 设置 这 个 文件 的 编码 格式 。 最 后 单 击 OK 按钮 。 


© Default (GBK) 
他 Other: Nre-s] S| 
wy | en | 


1.136 设置 文件 的 编码 格式 


要 & 键 的 运用 中 级 | 


力 实例 说 明 
在 Zend Studio 中， 通过 快捷 键 可 以 完成 很 多 操作 ， 快 捷 键 的 运用 可 以 为 开发 者 节省 很 多 时 间 ， 而 且 可 以 简 
化 操作 的 流程 。 在 本 实例 中 将 介绍 如 何 运用 Zend Studio 中 的 快捷 键 创建 PHP 项 目 。 


图 关键 技术 

要 应 用 Zend Studio 中 的 快捷 键 ， 必 须 了 解 快捷 键 代表 的 意义 。 在 Zend Studio 中 ， 选 择 “ 帮 助 ”/Key Assist 
命令 将 弹出 Zend Studio 中 的 快捷 键 列表 ， 或 者 也 可 以 直接 按 Ctrl+Shift+L 键 ， 同 样 可 以 弹出 快捷 键 列表 。 在 这 
个 列表 中 可 以 查看 到 所 有 快捷 键 代表 的 意义 ， 如 图 1.137 所 示 。 


PHP 开发 实例 大 全 (基础 着) 
pienson pe Cr 
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看 设计 过 程 
(1) 在 Zend Studio 中 创建 一 个 PHP 项 目 。 可 以 直接 使 用 快捷 键 Alt+ShifttrN， 将 弹出 一 个 菜单 命令 列表 ， 
选择 PHP Project 命令 ， 创 建 一 个 PHP 项 目 ， 如 图 1.138 所 示 。 


图 1.138 创建 PHP 项目 


(2) 进入 新 项 目 创建 窗口 中 ， 在 该 窗口 中 设置 项 目 名 称 为 01; 指定 项 目 文件 存储 位 置 ， 这 里 使 用 默认 值 ; 
选择 PHP 的 版 本 ， 设 置 是 否 支持 JavaScript 脚本 ， 如 图 1.139 所 示 。 


1.139 新 建 项 目 
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(3) 在 项 目 01 中 创建 PHP 文件 。 编写 一 个 简单 实例 ,同样 可 以 使 用 快捷 键 Alt+Shiftt+rN， 只 是 要 在 列表 中 
选择 PHP File 命令 ， 如 图 1.140 所 示 。 
(4) 进入 文件 创建 窗口 ， 定 义 文件 名 称 ， 最 后 单 击 Finish 按钮 ， 完 成 文件 的 创建 ， 如 图 1.141 所 示 。 


ES 


BH Nanter I 3 T_T 至 I 


1.140 创建 PHP 文件 


Source Folder |/01 


File Nane ~ [index| php 


Next > Einish 


图 1.141 创建 index.php 文件 


(5) 文件 创建 成 功 后 ， 就 可 以 在 编辑 区 中 编辑 文件 的 内 容 。 在 编辑 区 中 可 以 通过 快捷 键 Ctl+ShifttF 对 代 
码 进行 格式 化 ， 如 图 1.142 所 示 。 


S9 
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phpinfo0 函 数 的 提示 


四 | | pl smovens [Tashe | corece [WM serverr | » Deo Ovo 5 习 
图 1.142 编辑 PHP 代码 
(6) 编辑 完成 后 ， 保 存 该 文件 ， 单 击 网 | 按钮， 运行 程序 ， 运 行 结果 如 图 1.125 所 示 。 
图 秘笈 心 法 


心 法 领悟 032: 在 Zend Studio 中 使 用 快捷 键 。 
在 Zend Studio 中 ,对 于 快捷 键 的 使 用 不 必 机 械 地 去 记忆 ， 只 要 了 解 一 些 常用 的 快捷 键 即 可 。 对 于 初学 者 来 
说 ， 通 过 鼠标 进行 操作 比 使 用 快捷 键 更 好 ， 更 有 助 于 对 工具 功能 的 理解 和 学 习 。 


中 级 
趣味 指数 : 富 坪 商 容 


力 实例 说 明 


在 运行 PHP 程序 的 过 程 中 , 需要 将 PHP 程序 复制 到 Apache 服务 器 指定 的 根 目录 下 , 然后 在 正 浏览 器 的 地 
址 栏 中 输入 Le //127.0.0. 和 http: /localhost 来 运 云 行 行 PHP 程序 。 而 在 Zend Studio 中 可 以 直接 部 署 Apache 服 


HD A OED so 
je IB /TID.0.8. 
J 


四 /J 本 于 和 = 


jm I 加 
图 1.143 运行 程序 
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图 关键 技术 


在 Zend Studio 中 部 署 Apache 服务 器 ， 关 键 是 指定 正确 的 访问 路 径 ， 如 图 1.144 所 示 。 
和 


Er 
-ll 
| 


0 


(| Filter natehed 5 of 6 itens 


图 1.144 部 署 Apache 服务 器 的 访问 路 径 
如 果 在 图 1.144 所 示 的 界面 中 ， 没 有 指定 URL 中 访问 文件 的 具体 位 置 MR/01/001， 那 么 程序 就 不 能 正常 运 
行 ， 将 出 现 如 图 1.145 所 示 的 效果 。 


| 司 并 不 到 网 页 
您 要 查看 的 网 页 可 能 已 被 前 除 、 名 称 己 被 更 疏 ， 或 者 暂时 不 可 用 。 


请 尝试 以 下 操作 : 
。 加 果 您 已 经 在 地 址 栏 中 输入 该 网 页 的 地 址 ， 诸 确认 其 拼写 正确 。 
。 打开 localhost 主页 ， 热 后 查找 指向 您 感 兴趣 信息 的 链接 . 


， 尝试 其 他 链接 。 
， 寻找 Internet 上 的 信息 。 


J0TP 404 - 未 找到 文件 
TInternet Explorer 


图 1.145 未 指定 URL 访问 路 径 


力 设计 过 程 
在 Zend Studio 中 部 署 Apache 服务 器 的 操作 步 又 如 下 : 


(1) 创建 一 个 PHP 项目， 这 里 不 再 袭 述 。 
(2) 单 击 工具 栏 中 加 3 按钮 的 下 三 角 按钮 ， 将 弹出 一 个 下 拉 菜单 ， 选 择 Run Configurations 选项 ， 在 弹 
出 的 对 话 框 中 完成 对 Apache 服务 器 的 部 署 ， 包 括 文件 的 指定 ， 如 图 1.146 所 示 。URL 访问 路 径 的 设置 ， 如 


图 1.147 所 示 。 
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四 Cs 
-== 


图 1.146 设置 访问 文件 图 1.147 设置 URL 访问 路 径 
(3) 设置 完成 后 单 击 Run 按钮 ， 即 可 浏览 PHP 项 目 中 的 内 容 。 
笈 心 法 
心 法 领悟 033: 在 Zend Studio 中 修改 快捷 键 的 设置 。 


单 击 Window 按钮 ， 然 后 选择 Preferences 命令 ， 将 弹出 如 图 1.148 所 示 的 窗口 ， 可 以 在 其 中 完成 对 快捷 键 
的 修改 操作 。 
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图 1.148 ”Zend Studio 中 快捷 键 的 修改 步骤 
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基本 语法 
运算 符 
包含 语句 
条 件 语句 
循环 语句 
跳 转 语句 
自 定 义 轩 数 
字符 果 
正则 表达 式 
数组 
日 期 和 时 间 
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2.1 基本 语法 


也 许 你 是 一 个 PHP 初学 者 ， 当 你 向 有 经 验 的 PHP 高 级 程序 员 请 教 如 何 学 好 PHP 这 门 语 言 时 ， 想 必 他 会 问 
你 有 没有 其 他 编程 语言 的 基础 ， 如 果 有 的 话 ， 就 能 够 很 快 入 门 ， 学 起 来 也 很 轻松 。 

由 此 可 见 ， 掌 握 一 门 语言 是 多 么 的 重要 。 可 以 说 ， 扎 实 的 语言 基础 ， 是 培养 和 提高 程序 员 编程 能 力 的 基本 
途径 ,语言 基础 也 是 学 习 PHP 过 程 中 非常 重要 的 一 个 环节 , 它 在 很 大 程度 上 决定 了 程序 员 PHP 学 习 的 进展 效果 。 

另外 ， 程 序 员 的 创造 力 极 强 ， 可 以 完全 按照 自己 的 设计 目标 和 思路 组 织 代码 ， 用 与 其 他 程序 员 完全 不 同 的 
设计 方法 实现 完全 相同 的 功能 。 但 是 ， 编 程 同时 也 是 一 项 十 分 严谨 的 工作 ， 因 为 语法 是 严格 限定 的 ， 代 码 必须 
严格 遵守 语法 要 求 进行 书写 ， 任 何不 符合 规范 的 代码 都 不 能 被 计算 机 执行 ， 哪 怕 是 程序 员 写 错 一 个 字母 ， 或 者 
少 写 一 个 结束 符 都 会 使 程序 出 错 。 

所 以 ,程序 设计 语言 的 语法 必须 得 到 必要 的 重视 。 语 法 是 PHP 语言 的 规则 ， 打 好 这 个 基础 ， 循 序 渐进 地 学 
习 ， 实 际 运用 时 才 会 得 心 应 手 。 


mr 


趣味 指数 : 址 食 娘 三 | 


实例 034 


图 实例 说 明 


本 实例 应 用 PHP 标记 ， 通 过 echo 语句 和 phpinfo0 函 数 向 用 户 展示 PHP 的 配置 信息 ， 包 括 配 置 文 件 所 在 的 
目录 以 及 一 些 相关 扩展 库 的 版 本 、 作 者 信息 等 。 运 行 结果 如 图 2.1 所 示 。 


Streams 

Registered Stream 

Socket Transports 

Registered Stream |convert iconw,*, string rot13, string toupper string ,tolower, string,strip_tags, convert,*, consumed, zib,* 


图 2.1 PHP 配置 信息 
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力 关键 技术 
本 实例 的 关键 点 是 应 用 PHP 的 输出 语句 echo， 输 出 phpinfo0 函 数 的 返回 值 。phpinfo0 函 数 的 代码 如 下 ; 
该 因数 将 条 出 PHIP 的 配置 信息 。 

图 设计 过 程 
创建 mdex.php 文件 ， 应 用 PHP 标记 ， 通 过 echo 语句 输出 phpinfo0 函 数 的 返回 值 ， 其 代码 如 下 : 


<?php 
echo phpinfo0; /输出 PHP 配置 信息 
?> 


秘笈 心 法 

心 法 领悟 034: phpinfo0 函 数 的 具体 应 用 。 

在 实际 的 PHP 项 目 开 发 过 程 中 ， 用 户 加 载 的 任何 一 个 组 件 ， 在 phpinfo0 函 数 的 输出 页 面 中 都 会 显示 是 否 已 
经 获得 支持 ， 所 以 此 函数 的 应 用 对 初学 者 来 说 是 十 分 重要 的 。 


实例 035 


力 实例 说 明 


在 用 PHP 编写 的 网 站 中 ， 经 常 需要 获取 当前 时 间 。 例 如 用 户 在 什么 时 间 登 录 的 网 站 、 黑 客 攻 击 网 站 是 在 什 
么 时 间 等 。 本 实例 应 用 PHP 标记 ， 通 过 echo 语句 和 date0) 函 数 来 实现 获取 服务 器 时 间 ， 并 进行 打印 。 运 行 结果 
如 图 2.2 所 示 。 


要 红 旬 当 前 大 问 是 


图 2.2 系统 当前 时 间 


力 关键 技术 


本 实例 主要 通过 ed ed 其 语法 及 说 明 如 下 : 
date(string format,int ti 


参数 format 指定 日期 和 时 间 输 出 的 格式 ， 如 表 2.1 所 示 ， 参 数 timestamp 为 可 选 参数 ， 指 定时 间 戳 ， 如 果 没 
有 指定 时 间 戳 ， 则 使 用 本 地 时 间 time(。 


表 2.1 参数 format 的 格式 化 选项 
参数 说 有 明 


a 小 写 的 上 午 和 下 午 值 ， 返 回 值 为 am 或 pm 

A 大 写 的 上 午 和 下 午 值 ， 返 回 值 为 AM 或 PM 

B Swatch Internet 标准 时 间 ， 返 回 值 为 000~999 

d 月 份 中 的 第 几 天 ， 有 前 导 0 的 2 位 数字 ， 返 回 值 为 01~31 


D 星期 中 的 第 几 天 ， 文 本 格式 ，3 个 字母 ， 返 回 值 为 Mon~Sun 
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续 表 


参数 说 明 


月 份 ， 完 整 的 文本 格式 ， 返 回 值 为 January~December 


小 时 ，12 小 时 格式 ， 没 有 前 导 0， 返 回 值 为 1~12 


QA ln | 


小 时 ，24 小 时 格式 ， 没 有 前 导 0， 返 回 值 为 0~23 


i 有 前 导 0 的 分 钟 数 ， 返 回 值 为 00~59 


I 判断 是 否 为 夏令 时 ， 如 果 是 夏令 时 ， 返 回 值 为 1， 否 则 为 0 


月 份 中 的 第 几 天 ， 没 有 前 导 0， 返 回 值 为 1~31 


星期 数 ， 完 整 的 文本 格式 ， 返 回 值 为 Sunday~Saturday 


判断 是 否 为 半年 ， 如 果 是 冰 年 ， 返 回 值 为 1， 否则 为 0 


数字 表示 的 月 份 ， 有 前 导 0， 返 回 值 为 01~12 


3 个 字母 缩写 表示 的 月 份 ， 返 回 值 为 Jan~Dec 

数字 表示 的 月 份 ， 没 有 前 导 0， 返 回 值 为 1~12 

与 格林 威 治 时 间 相 差 的 小 时 数 ， 如 0200 

RFC 822 格式 的 日 期 ， 如 Thu.21 Dec 2000 16:01:07 +0200 

秒 数 ， 有 前 导 0， 返 回 值 为 00~59 

每 月 天 数 后 面 的 英文 后 级 ， 两 个 字符 ， 如 st、nd、rd 或 者 也 ， 可 以 和 j 一 起 使 用 
指定 月 份 所 应 有 的 天 数 

本 机 所 在 的 时 区 
从 UNIX 纪元 〈January 1 1970 00:00:00 GMT) 开始 至 今 的 秒 数 

星期 中 的 第 几 天 ， 数 字 表示 ， 返 回 值 为 0~6 

ISO-8601 格式 年 份 中 的 第 几 周 ， 每 周 从 星期 一 开始 

2 位 数字 表示 的 年 份 ， 如 88、08 

4 位 数字 完整 表示 的 年 份 ， 如 1998、2008 

年 份 中 的 第 几 天 ， 返 回 值 为 0-366 

时 差 偏 移 量 的 秒 数 。UTC 西边 的 时 区 偏 移 量 总 是 负 的 ，UTC 东边 的 时 区 偏 移 量 总 是 正 的 ， 返 回 值 为 
一 43200-43200 


ool: lz |8 Ic |~ I~: 
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力 设计 过 程 


创建 index.php 文件 ， 通 过 echo 语句 输出 date0 函 数 的 返回 值 ， 其 代码 如 下 : 
< 


echo date('Y-m-s H:i:s); /| 输 出 当前 时 间 
> 


国 秘笈 心 法 


心 法 领悟 035， 对 系统 时 间 的 设置 。 
看 了 上 面 的 实例 ， 读 者 也 许 会 感到 奇怪 ， 为 什么 系统 当前 的 时 间 比 正常 的 时 间 少 了 8 个 小 时 ? 原因 是 系统 


输出 的 当前 时 间 是 系统 默认 的 格林 威 治 时 间 ， 而 不 是 我 们 所 使 用 的 东 八 区 的 北京 时 间 。 


想 要 更 改 为 东 八 区 的 时 间 ， 有 两 种 方法 : 
(1) 修改 php.ini 文件 中 的 设置 ， 找 到 [date] 下 的 “;date.timezone = ”选项 ， 将 该 项 修改 为 “date.timezone 


=Asia/Hong Kong”， 然 后 重启 Apache 服务 器 。 
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(2) 在 程序 中 ， 通 过 在 使 用 日 期 格式 之 前 添加 “date_default_timezone _set(timezone);” 函 数 来 完成 对 时 区 
的 设置 。 参数 timezone 为 PHP 可 识别 的 时 区 名 称 , 如 果 PHP 无 法 识别 时 区 名 称 , 则 系统 采用 UTC 时 区 。 在 PHP 
手册 中 提供 了 各 时 区 的 名 称 列表 ， 其 中 北京 时 间 可 以 设置 时 区 为 PRC (中华 人民 共 和 国 ) 、Asia/Chongqing( 重 
庆 ) 、Asia/Shanghai (上 海 ) 、Asia/Urumqi (乌鲁木齐 ) ， 这 几 个 时 间 是 等 效 的 。 


上 加 说 明 : 系统 默认 的 格林 威 治标 准时 间 (Greenwich Mean Time，GMT) 与 北京 时 间 相差 8 个 小 时 ， 在 国际 无 
线 电 通信 和 领域， 使 用 一 个 统一 的 时 间 ， 称 为 通用 协调 时 间 (Universal Time Coordinated，UTC) 。UTC 
与 格林 威 治标 准时 间 相同 。 
设置 完成 后 ， 时 间 显 示 如 图 2.3 所 示 。 


实例 036 高 级 | 


趣味 指数 : 容 但 全 伍 : 
实例 说 明 


很 多 时 候 用 户 需要 编写 包含 文件 路 径 及 文件 名 称 的 代码 ， 如 果 通 过 目录 查找 ， 未 免 有 些 麻 烦 。 这 时 用 户 可 
以 使 用 _FILE_ 预 定义 函数 。 本 实例 通过 ”FILE_ 预 定义 常量 获取 目标 文件 的 路 径 及 文件 名 称 并 在 网 页 上 进行 
打印 ， 运 行 结果 如 图 2.4 所 示 。 


C\AppServ\w MRONOaGinderphn 


2.4 输出 当前 文件 路 径 和 名 称 


力 关键 技术 


系统 预定 义 常量 和 用 户 自 定义 常量 在 使 用 上 没有 差别 。 大 多 数 预定 义 常 量 的 执行 结果 都 是 服务 器 的 相关 信 
息 (版 本 号 、 路 径 、 错 误 参 数 等 ) ， 所 以 程序 员 很 少将 此 函数 用 于 网 站 前 台 的 开发 ， 因 为 如 果 被 别有用心 的 人 
知道 了 这 些 信息 ， 会 严重 威胁 服务 器 的 安全 。 使 用 此 函数 的 语法 说 明 如 下 : 

__FILE _ 预 定义 常量 : 文件 的 完整 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 文件 名 。 自 PHP 4.0.2 
起 ，_FILE ”总 是 包含 一 个 绝对 路 径 ， 而 在 此 之 前 的 版 本 有 时 会 包含 一 个 相对 路 径 。 


图 设计 过 程 
创建 index.php 文件 ， 通 过 echo 语句 输出 _FILE_ 预 定义 常量 ， 其 代码 如 下 : 
<Iphp 


echo_ FILE :; /获取 文件 的 完整 路 径 
2> 


国 秘笈 心 法 


心 法 领悟 036: 预定 义 常量 的 说 明 。 
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PHP 中 可 以 使 用 预定 义 常量 获取 PHP 中 的 信息 ， 常 用 的 预定 义 常量 如 表 2.2 所 示 。 
表 2.2 ”PHP 的 预定 义 常量 


常 量 名 功 能 
FILE 默认 常量 ，PHP 程序 文件 名 
LINE 默认 常量 ，PHP 程序 行 数 
PHP VERSION 内 建 常量 ，PHP 程序 的 版 本 ， 如 3.0.8_dev 
PHP OS 内 建 常量 ， 执 行 PHP 解析 器 的 操作 系统 名 称 ， 如 Windows 
TRUE 该 常量 是 一 个 真 值 (TRUE) 
FALSE 该 常量 是 一 个 假 值 (FALSE) 
NULL 一 个 NULL 值 
E ERROR 该 常量 指 到 最 近 的 错误 处 
E WARNING 该 常量 指 到 最 近 的 警告 处 
E PARSE 该 常量 指 到 解析 语法 有 潜在 问题 处 
E NOTICE 该 常量 指 到 不 寻常 但 不 一 定 是 错误 处 


< 注意 :FILE 和 _ LINE 中 的 “_ ”是 两 条 下 划 线 ， 而 不 是 一 条 “_”。 表 中 以 上 开头 的 预定 义 常量 是 
PHP 的 错误 调试 部 分 。 如 果 想 详细 了 解 ， 请 参考 error reporting(0) 函 数 。 


高 级 | 
实例 037 起 味 指数 : 友良 志雄 ， 
实例 说 明 


输出 或 定义 字符 串 时 高 不 开 单 引号 和 双 引 号 的 修饰 ,表面 上 看 它们 似乎 没有 什么 不 同 ,实际 上 是 有 区 别 的 。 
本 实例 应 用 单 引号 与 双 引号 操作 符 来 说 明 如 何 区 分 单 引 号 和 双 引 号 ， 运 行 结果 如 图 2.5 所 示 。 


输出 字符 串 
输出 字符 串 $a 
2.5 区 分 单 引号 和 双 引 号 


力 关键 技术 


本 实例 的 关键 点 是 输出 单 引号 和 双 引 号 修饰 的 字符 串 以 显示 其 区 别 。 
使 用 双 引 号 与 单 引号 最 大 的 区 别 是 ， 双 引号 中 所 包含 的 变量 会 自动 被 替换 成 实际 数值 ， 而 在 单 引号 中 包含 
的 变量 则 按 普通 字符 串 输出 。 


图 设计 过 程 


创建 index.php 文件 ， 通 过 echo 语句 输出 用 单 、 双 引号 修饰 的 字符 串 ， 其 代码 如 下 : 
<?php 

es 

ccho 答 出 字符 串 Sa'; 


> 
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心 法 领悟 037: 转 义 字符 。 
通过 双 引 号 定义 字符 串 ， 可 以 支持 很 多 的 转 义 字符 。 如 表 2.3 所 示 为 双 引号 支持 的 转 义 字符 。 


表 2.3 双 引 号 支持 的 转 义 字符 


转 义 字符 含 义 
un 换行 (LF 或 ASCII 字符 0x0A (10) ) 
Yr 回 车 (CR 或 ASCII 字符 0x0D (13) ) 
Vt 水 平 制 表 符 (HT 或 ASCI 字符 0x09 (9) ) 
\ 反 斜 杠 
'§ 美元 符号 
V 单 引号 
Ww 双 引 号 
\[0-7]{1.3} 此 正则 表达 式 序列 匹配 一 个 用 八进制 符号 表示 的 字符 ， 如 \467 
\x[0-9A-Fa-f]{1.2} 此 正则 表达 式 序列 匹配 一 个 用 十 六 进 制 符 号 表示 的 字符 ， 如 wx9f 


Wn 和 \r 在 Windows 系统 中 没有 什么 区 别 ， 都 可 以 当 作 回 车 符 ， 但 在 Linux 系统 中 则 是 两 种 效果 。 在 Linux 
中 ， 表示 换 到 下 一 行 ， 却 不 会 回 到 行 首 ， 而 \ 表示 光标 会 回 到 行 首 ， 但 仍然 在 本 行 。 如 果 读 者 使 用 Linux 操 
作 系 统 ， 可 以 尝试 一 下 这 两 个 转 义 字符 的 应 用 。 


_Bg 技巧 : 在 定义 简单 的 字符 囊 时 ， 使 用 单 引号 是 比较 合适 的 处 理 方式 。 如 果 使 用 双 引 号 ，PHP 将 花费 一 些 时 
间 来 处 理 字符 串 的 转 义 和 变量 的 解析 。 因 此 ， 笔 者 建议 在 定义 字符 串 时 ， 如 果 没有 特别 的 要 求 ， 应 
该 尽量 使 用 单 引号 。 通 过 单 引 号 定义 的 字符 串 类 型 变量 按照 普通 字符 进行 输出 。 例 如 ， 通 过 单 引 号 
定义 字符 串 '$result， 那 么 将 输出 '$result， 而 不 会 输出 变量 $result 的 实际 值 。 


[ED 说 明 : (1) 在 字符 囊 中 表示 单 引号 ， 需 要 使 用 反 斜 线 “\” 进 行 转 义 。 例 如 ， 定 义 一 个 字符 囊 “Its dogged 
that does it.”， 则 需要 写 出 “It\'s dogged that does it.”。 
(2) 在 单 引 号 或 者 字符 串 结束 位 置 表 示 反 斜 线 ， 同 样 要 用 反 斜 线 进行 转 义 ， 即 用 两 个 反 斜 线 “\\” 
表示 。 例 如 ， 表 示 字 符 串 “F:\PkKhPHPWWww”， 则 要 写 出 “F:\PkKhPHP\Wwww”。 


力 实例 说 明 


JavaScript 语言 是 一 门 功能 强大 的 客户 端 脚本 语言 ， 也 是 一 门 跨 平 台 语言 。PHP 支持 使 用 JavaScript 编码 。 
本 实例 通过 PHP 5.0 新 型 字符 串 动态 输出 JavaScript 代码 ， 运 行 结果 如 图 2.6 所 示 。 


| 来自 http://1ocalhost 的 页 面 说 : 


和 欢迎 进入 PHP 编 程 世 界 t 9? ? 


图 2.6 动态 输出 JavaScript 代码 
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图 关键 技术 


PHP 5.0 新 型 字符 串 的 使 用 是 本 实例 的 关键 。PHP 5.0 这 种 新 型 的 字符 串 是 以 “<<<” 开 始 ， 后 面 紧 跟着 字 
符 串 开始 标记 ， 之 后 为 字符 串 的 内 容 ， 最 后 以 标记 加 分 号 (本 实例 以 mark 作为 结束 标记 ) 结束 。 本 函数 一 般 用 
于 对 HTML 代码 的 格式 输出 。 


力 设计 过 程 
创建 index.php 文件 ， 通 过 PHP 5.0 新 型 字符 串 实现 实例 ， 其 代码 如 下 : 
<?php 
Sstr=<<<mark //PHP 5.0 新 型 字符 串 开始 部 分 
<script language="javascript" type="text/javascript"> //JavaScript 代码 
alert(" 欢 迎 进入 PHP 编程 世界 ! ! !"); /| 输出 提示 
</script> /| 结束 标记 
1 /新 型 字符 串 介绍 标记 
echo $str; /| 输出 字符 串 
?> 
图 秘笈 心 ; 


心 法 领悟 038: 新 型 字符 串 。 
笔者 认为 ， 新 型 字符 串 是 将 以 往 在 HTML 标签 中 嵌 套 PHP 标签 的 方式 做 了 一 次 有 效 的 逆转 。 


- ee ji 
力 实例 说 明 


在 PHP 手册 中 经 常会 看 到 一 些 返回 值 为 Boolean 的 函数 ,函数 说 明 的 讲解 可 能 是 当 符合 条 件 时 , 返回 值 
为 1， 和 否则 返回 值 为 0。 按照 正常 的 思维 ， 返 回 值 应 该 是 TRUE 和 FALSE， 因 为 它们 才 是 真正 的 Boolean 类 
型 。 其 实 这 些 都 是 类 型 转换 的 应 用 。 本 实例 介绍 PHP 中 的 数据 类 型 ， 展 示 数 据 是 如 何 进行 类 型 转换 的 ， 运 
行 结果 如 图 2.7 所 示 。 


自动 类 型 转换 : 
104 我 是 字符 串 型 数据 = 
强制 类 型 转换 ， 


图 2.7 当 数 字 遇 到 了 字符 串 


力 关键 技术 


虽然 PHP 是 弱 类 型 语言 ， 但 有 时 仍然 需要 用 到 类 型 转换 。PHP 中 的 类 型 转换 和 C 语言 一 样 ， 非 常 简单 。 本 
实例 的 关键 点 是 运用 类 型 转换 的 特点 进行 输出 。 

(1) 系统 根据 情况 自动 转换 数据 类 型 称 为 自动 转换 。 

(2) 用 户 在 变量 名 称 前 将 想 要 转换 的 数据 类 型 写 到 括号 内 称 为 强制 转换 。 


力 设计 过 程 
(1) 创建 PHP 脚本 ， 通 过 echo 语句 输出 想 要 转换 的 变量 ， 其 代码 如 下 : 
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<?php 
$a= 10; / 整 型 数据 
和 = "我 是 字符 串 型 数据 "; /字符 串 类 型 数据 
Se=$a+t $b; 


Sf= $b+ Sa; 

echo "自动 类 型 转换 : <br>"; 

echo '10+ 我 是 字符 串 型 数据 ='.Se."<br>"; 

echo "强制 类 型 转换 。<br>"; 

echo '10+ 我 是 字符 串 型 数据 ='.(string)$e."<br>"; 
> 


(2) 将 文件 存储 于 \MR\02\039 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.7 所 示 。 
力 秘笈 心 法 


心 法 领悟 039: 类 型 转换 的 相关 说 明 。 
(1) 转换 成 整 型 。 在 将 非 整 型 数据 转换 成 整 型 时 ， 方 法 是 在 变量 前 使 用 “(integeD ”或 者 “Ginb”， 转 换 规则 如 下 。 
回 ” 浮 点 型 转换 成 整 型 ， 小 数 点 后 的 数 将 被 舍弃 ， 如 果 浮 点 数 超出 整数 取 值 范围 ， 那 么 将 无 法 得 到 有 效 的 
整 型 结果 ， 结 果 可 能 是 0 或 者 整 型 的 最 小 负数 。 
加 ”布尔 型 转换 成 整 型 TRUE 将 转换 为 1，FALSE 将 转换 为 0。 
加 ”字符 串 型 转换 为 整 型 ,将 会 对 字符 串 左 侧 的 第 1 位 进行 判断 。 如 果 第 1 位 是 数字 ， 则 从 第 1 位 开始 将 
读 取 到 的 数字 转换 成 整 型 ， 如 果 第 1 位 不 是 数字 ， 则 结果 为 0。 
(2) 转换 成 浮 点 型 。 方 法 是 在 变量 前 使 用 “(float)”， 转 换 规则 如 下 : 
回 ” 整 型 转换 为 浮 点 型 ， 其 结果 不 会 发 生变 化 。 
回 “布尔 型 转换 为 浮 点 型 ， TRUE 将 转换 为 1，FALSE 将 转换 为 0。 
回 “字符 串 型 转换 为 浮 点 型 ; 如 果 字 符 串 中 包含 小 数 点 “.” 或 科学 记 数 法 的 e 或 者 E 中 的 任何 一 个 字符 ， 
字符 串 被 当 作 浮 点 型 处 理 ， 否 则 ， 被 视 为 整 型 。 
(3) 转换 成 字符 串 型 。 方 法 是 在 变量 前 使 用 “(string)”， 和 转换 规则 如 下 。 
整 型 或 者 浮 点 型 转换 成 字符 串 型 ， 转 换 结果 为 其 数值 。 
回 “ 布尔 型 转换 为 字符 串 型 : TRUE 将 转换 为 字符 串 “1”，FALSE 将 转换 为 空 字符 串 。 
回 “ 对象 或 者 数组 型 转换 成 字符 串 型 :转换 结果 为 字符 串 对 象 或 者 字符 串 数组 。 
回 ”资源 型 转换 成 字符 串 型 : 转换 结果 为 一 个 类 似 “Resource id# ”的 字符 串 。 在 “#"” 之 后 是 PHP 在 运行 
时 分 配给 该 资源 的 标识 代号 。 
(4) 转换 成 布尔 型 。 方 法 是 在 变量 前 使 用 “(boolean)” 或 者 “(bool)”。 因 为 布尔 型 只 包含 两 个 值 ，TRUE 
和 FALSE， 所 以 其 转换 规则 包括 两 种 。 
第 一 种 ， 转 换 结 果 为 FALSE 的 情况 。 
整 型 或 者 浮 点 型 数 0。 
空 字符 串 和 字符 串 “0”。 
没有 任何 元 素 的 空 数 组 。 
没有 任何 元 素 的 对 象 。 
特殊 类 型 NULL。 
第 二 种 ， 转 换 结果 为 TRUE 的 情况 。 排 除 在 第 一 方面 说 明 的 情况 ， 其 他 转换 结果 都 为 TRUE。 
(5) 转换 成 数组 。 方 法 是 在 变量 前 使 用 “(array)”， 转 换 规则 是 : 将 非 数 组 型 转换 成 与 原 变量 数据 类 型 相 
同 的 数组 ， 数 组 中 只 有 一 个 元 素 。 
(6) 转换 成 对 象 。 方 法 是 在 变量 前 使 用 “(object)”， 转 换 规则 是 : 将 非 对 象 型 转换 成 一 个 新 的 对 象 ， 其 中 
名 为 scalar 的 成 员 变量 将 包含 原 变量 的 值 。 


因 因 办 办 加 
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实例 040 


力 实例 说 明 


大 楼 盖 得 好 不 好 主要 在 于 地 基 是 否 牢固 ， 变 量 就 是 PHP 编程 的 地 基 。 本 实例 介绍 变量 的 定义 与 应 用 ， 通 过 
echo 语句 实现 打印 “Hello World!!!” 的 小 程序 ， 运 行 结果 如 图 2.8 所 示 。 


Hello World!!! 


图 2.8 Hello World 程序 


图 关键 技术 


本 实例 的 关键 点 是 用 “$” 符 号 定义 变量 ， 通 过 echo 语句 输出 变量 。PHP 中 的 变量 使 用 “$” 加 变量 名 来 表 
示 ， 变 量 名 是 区 分 大 小 写 的 。 使 用 变量 时 ， 只 需 对 变量 直接 赋值 即 可 。 变 量 赋值 ， 是 指 给 变量 一 个 具体 的 数据 
值 ， 对 于 字符 串 和 数字 类 型 的 变量 ， 可 以 通过 “=” 来 实现 ， 其 格式 如 下 

Sname = value; 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 定 义 字符 串 变量 值 为 “Hello World!!!”， 通 过 echo 语句 输出 定义 的 变量 ， 其 代 


码 如 下 : 
<?php 
$str = "Hello World!!!"; // 定 义 变量 
echo $str; /输出 变量 
?> 


(2) 将 该 文件 存储 于 \MR\02\040 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.8 所 示 。 
秘笈 心 法 
心 法 领悟 040: 变量 的 作用 域 。 
变量 有 其 自己 的 作用 域 ， 不 同 的 作用 域 有 不 同 的 作用 范围 ， 就 像 清华 大 学 学 生 的 学 生 证 不 能 在 北京 大 学 的 


图 书馆 借阅 图 书 一 样 。 
变量 按 其 作用 域 可 以 分 为 全 局 变量 、 局 部 变量 和 静态 变量 ， 变 量 作用 域 的 说 明 如 表 2.4 所 示 。 


表 2.4 变量 作用 域 的 说 明 


即 被 定义 在 所 有 函数 以 外 的 变量 ， 其 作用 域 是 整个 PHP 文件 ， 但 是 在 用 户 自 定义 函数 内 部 是 不 可 用 的 。 
全 局 变量 《| 想 在 用 户 自 定义 函数 内 部 使 用 全 局 变量 , 要 使 用 global 关键 字 声明 , 或 者 通过 使 用 全 局 数组 $globals 进行 
访问 


局 部 变量 | 即 在 函数 的 内 部 定义 的 变量 ， 这 些 变量 只 限于 在 函数 内 部 使 用 ， 不 能 在 函数 外 部 使 用 


能 够 在 函数 调用 结束 后 保留 变量 值 ， 当 再 次 回 到 其 作用 域 时 ， 又 可 以 继续 使 用 原来 的 值 。 而 一 般 变 量 在 
静态 变量 《| 函数 调用 结束 后 ， 其 存储 的 数据 值 将 被 清除 ， 所 占 的 内 存 空 间 被 释放 。 使 用 静态 变量 时 ， 先 要 用 关键 字 
static 来 声明 变量 需要 把 关键 字 static 放 在 要 定义 的 变量 之 前 ) 


< 注意 : 在 函数 的 内 部 定义 的 变量 ， 其 作用 域 是 所 在 函数 。 如 果 在 函数 外 赋值 ， 将 被 认为 是 完全 不 同 的 另 一 
个 变量 。 在 退出 声明 变量 的 函数 时 ， 该 变量 及 相应 的 值 就 会 被 撤销 。 
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力 实例 说 明 


PHP 编程 语言 中 预定 义 了 很 多 有 用 的 变量 ， 这 些 变量 往往 起 着 非常 重要 的 作用 。 本 实例 讲解 预定 义 变量 
$_ENV 的 相关 知识 ， Die ainda 运行 结果 如 图 2.9 所 示 。 


NO [NUMBER OF_PROCESSORS. 
\system32;C: \NINDOWS; C: \h S\Systen32\WNben 
BE . CRD; . VBS; . VBE; . JS/ | -WSFS NSH 
=> x86u[PRDCESSOR_IDENTIF x86 Eanily 15 
ntel [PROCESSORALEVEL] 
[ProgranFi 1 3) =>C: \ 
- RDORS\TENE 


and 
Settings\LocAalSetvi windir] => C: AWINDONS [APp _PID] => 292 ) 


图 2.9 预定 义 变量 的 应 用 


力 关键 技术 


PHP 提供 的 预定 义 变量 有 很 多 是 非常 实用 的 ， 通 过 这 些 预定 义 变量 可 以 获取 到 用 户 会 话 、 用 户 操作 系统 的 
环境 和 本 地 操作 系统 的 环境 等 信息 ， 其 中 $_ENV 是 执行 环境 提交 至 脚本 的 变量 。 


看 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 通 过 print r 语句 输出 系统 预定 义 变量 ， 其 代码 如 下 : 

EE print x($_ENV); // 打 印 系统 的 环境 变量 

(2) 将 该 文件 存储 于 \MR\02\041 文件 夹 下 ， 命 名 为 index.php， 运 行 结果 如 图 2.9 所 示 。 
图 秘笈 心 ; 


心 法 领悟 041: 重要 的 系统 预定 义 变量 。 
系统 的 预定 义 变量 是 比较 常用 的 技术 ， 读 者 必须 牢记 ， 尤 其 是 S_ FILES、$_POST、$_GET 和 $_SESSION。 


高 级 


实例 042 趣味 指数 : 但 食 三 食 


力 实例 说 明 


变量 包括 预定 义 变量 、 可 变 变量 等 ， 预 定义 变量 在 实例 041 中 已 经 做 了 简要 介绍 ， 本 实例 通过 可 变 变 量 实 
现 输出 指定 字符 串 ， 运 行 结 果 如 图 2.10 所 示 。 


项 ERHP ， 
图 2.10 使 用 可 变 变 量 输出 
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图 关键 技术 


可 变 变量 是 一 种 独特 的 变量 ， 它 允许 动态 改变 一 个 变量 名 称 ， 其 工作 原理 是 该 变量 的 名 称 由 另外 一 个 变量 
的 值 来 确定 。 实 现 过 程 是 在 变量 前 多 加 一 个 “S$” 符号 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 定义 一 个 字符 串 变 量 ， 然 后 在 第 1 个 字符 串 变 量 的 值 前 加 一 个 “$” 作 为 第 


2 个 变量 的 变量 名 ， 最 后 通过 echo 语句 输出 可 变 变量 ， 其 代码 如 下 : 
php 


$str name ="str_ name 1"; /定义 变量 
S$str name_ 1 = "TILike PHP!"; // 定 义 可 变 变 量 
echo $$str name; /输出 可 变 变量 
?> 
(2) 将 该 文件 存储 于 \MR\02\042 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.10 所 示 。 


心 法 领悟 042: 可 变 变 量 。 
可 变 变 量 即 是 将 两 个 变量 的 值 使 用 一 个 变量 命名 进行 操作 , 但 是 要 注意 被 引用 的 变量 名 前 要 再 加 上 一 个 “$” 
符号 。 


高 级 | 


实例 043 趣味 指数 : 请 食 傅 良 | 


力 实例 说 明 


在 定义 长 字符 串 变 量 时 ， 字 符 串 本 身 往往 包含 一 些 特殊 字符 。 例 如 ， 字 符 串 本 身 包含 双 引 号 (") ， 这 时 就 
需要 使 用 转 义 字符 对 特殊 字符 进行 转 义 。 本 实例 通过 转 义 字符 “\” 转 义 经 特殊 字符 双 引号 〈") 包含 的 字符 串 ， 
运行 结果 如 图 2.11 所 示 。 


“FHP 是 一 门 Web 开 发 最 火 的 编程 语言 。 
图 2.11 使 用 转 义 字符 输出 特殊 字符 


图 关键 技术 


本 实例 的 关键 点 是 转 义 字符 “\” 的 使 用 ， 它 除了 可 以 做 转 义 字符 外 ， 还 有 一 些 其 他 功能 ， 即 可 以 将 一 些 不 
可 打印 的 字符 显示 出 来 ， 如 a、W\b、\e、Yf、wm、\r 和 \t 等 。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 通 过 echo 语句 输出 经 转 义 字符 转 义 的 特殊 字符 ， 其 代码 如 下 : 

<?php 


echo "\"PHP 是 一 门 Web 开发 最 火 的 编程 语言 "": /输出 转 义 字符 转 义 的 字符 串 
?> 


(2) 将 该 文件 存储 于 \MR\02\043 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.11 所 示 。 
力 秘笈 心 法 
心 法 领悟 043: 转 义 字符 的 功能 。 
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转 义 字符 的 功能 只 有 一 个 ， 就 是 将 特殊 字符 转 义 成 普通 字符 。 
力 实例 说 明 


常量 是 PHP 编程 基础 的 重要 组 成 部 分 ， 其 作用 是 定义 一 个 不 会 改变 的 值 。 本 实例 通过 计算 圆 的 面积 向 用 户 
说 明 常 量 是 如 何 定义 和 使 用 的 ， 运 行 结 果 如 图 2.12 所 示 。 


半径 为 10 个 单位 的 圆 的 15926 


图 2.12 使 用 常量 指定 PI 的 值 计算 圆 的 面积 


力 关键 技术 


PHP 中 通常 使 用 define0 函 数 来 定义 常量 ; 使 用 constant0 函 数 动态 获取 常量 值 ; 使 用 defined() 函 数 判断 一 个 
常量 是 否 已 经 定义 ， 使 用 get_defined_constants() 函 数 获取 所 有 当前 已 经 定义 的 常量 。 其 中 ，define() 函 数 的 语法 


i 

参数 说 明 : 

string name: 必 选 参数 ， 常 量 名 称 ， 即 标识 符 。 

mixed value: 必 选 参数 ， 常 量 的 值 。 

bool case_insensitive: 可 选 参数 ， 指 定 大 小 写 是 否 敏 感 。 设 定 为 TRUE， 表 示 不 敏感 。 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 首 先 通 过 define0 函 数 定 义 常量 ,将 数值 “3.1415926” 赋 给 常量 PI，， 然 后 定义 
数值 型 变量 ， 将 圆 的 半径 设 定 为 10 个 单位 。 最 后 通过 echo 语句 输出 圆 面积 ， 其 代码 如 下 : 

<php 


define("PI",3.1415926); /定义 常量 
$r=10; /定义 圆 半径 
echo "半径 为 10 个 单位 的 圆 的 面积 ".PI*($r*$r); /定义 圆 面积 
?> 
(2) 将 该 文件 存储 于 \MR\02\044 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.12 所 示 。 
图 秘笈 心 法 


心 法 领悟 044: 使 用 define() 函 数 定义 常量 的 注意 事项 。 
使 用 defineO 函 数 定义 的 常量 一 旦 定义 就 不 能 改变 或 者 取消 。 


22 运算 符 
运算 符 是 用 来 对 变量 、 常 量 或 数据 进行 计算 的 符号 ， 是 对 一 个 值 或 一 组 值 执行 一 个 指定 的 操作 。PHP 的 运 


算 符 包括 字符 串 运算 符 、 算 术 运 算 符 、 赋 值 运算 符 、 递 增 或 递减 运算 符 、 位 运算 符 、 逮 辑 运算 符 、 比 较 运算 符 
和 条 件 运算 符 。 
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实例 045 


力 实例 说 明 


运算 符 是 表达 式 的 组 成 部 分 ， 没 有 运算 符 的 表达 式 是 不 存在 的 。 本 实例 通过 使 用 算术 运算 符 设置 数字 的 加 
密 / 解 密 算法 ， 运 行 结果 如 图 2.13 和 图 2.14 所 示 。 


8 数字 令 : |1081 
人 1084, 1415926 解密 口令 1081 | 


图 2.13 口令 加 密 图 2.14 口令 解密 


力 关键 技术 


本 实例 的 关键 点 是 将 数字 进行 算术 运算 进而 得 到 加 密 /解密 结果 。 算 术 运 算 (Arithmetic Operators) 符号 是 
处 理 四 则 运算 的 符号 ， 在 数字 处 理 中 应 用 得 最 多 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 定义 常量 ， 将 数值 “3.1415926” 赋 给 常量 PI。 然 后 编写 自 定义 函数 ， 在 自 
定义 函数 方法 体内 定义 加 密 或 解密 算法 。 最 后 ， 当 表单 提交 后 ， 调 用 对 应 的 加 密 或 解密 算法 ， 并 输出 结果 ， 其 
代码 如 下 : 
<?php 
echo "<form action=" method='post>"; // 输 出 表单 
echo "数字 口令 : <input name='text type='text>"; 


echo "<input type='submit name='sub' valuc= 确 定 >"; 
echo "</form>"; 


define("PI",3.1415926); /定义 常量 
funetion Encrypt($str){ // 自 定义 加 密 算法 
return $str = $str + PI; // 将 口令 与 常量 相 加 
} 
function Decrypt(Sstr){ // 自 定义 解密 算法 
retum $str = $str - PI; // 将 加 密 后 口令 与 常量 相 减 
} 
if($_POST[sub){ // 通 过 POST 方式 传 参 
echo "加 密 口 令 &nbsp;&nbsp;".Encrypt($_POST[text])."<br>"; // 取 得 加 密 后 的 结果 
$_SESSION[pwd] = Encrypt($_POST[text]): // 保 存在 SESSION 中 
<a href='index.php?pwd=1 人 > 解密 口令 </a> // 超 链接 
<?php 
iflisset($_GET[pwd]){ // 判 断 地 址 栏 中 是 否 存在 pwd 
echo "解密 口令 &nbsp:&nbsp:" Decrypt($_SESSION[pwd]): /口令 解密 


?> 


(2) 将 该 文件 存储 于 \MR\02\045 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.13 和 图 2.14 所 示 。 
国 秘笈 心 ; 


心 法 领悟 045: 运算 符 的 优先 级 。 
本 实例 并 没有 联合 应 用 多 种 运算 符 ， 当 联合 应 用 时 要 注意 运算 符 优先 级 的 问题 。 所 谓 的 优先 级 就 是 先进 行 
哪 种 运算 再 进行 哪 种 运算 符 的 运算 。 为 了 方便 ， 笔 者 将 运算 符 的 优先 级 进行 归 类 ， 如 表 2.5 所 示 。 
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表 2.5 运算 符 的 优先 级 


优先 级 别 运 算 符 

1 ++， 一 

于 +， 一 〈 正 、 负 号 运算 符 ) ，!，~ 
3 #，/，9% 

4 

本 

6 

7 

8 

9 


实例 046 


力 实例 说 明 


在 一 些 程序 中 ， 经 常 需要 将 两 个 时 间 进 行 比较 ， 但 是 由 于 时 间 是 由 年 、 月 、 日 、 时 、 分 、 秒 组 成 的 ， 比 较 
起 来 很 不 方便 ， 这 时 可 以 把 时 间 转 换 成 时 间 惟 来 进行 比较 。 本 实例 通过 date0、strtotime0 和 ceil0 函 数 实现 比较 
两 个 时 间 戳 的 大 小 ， 运 行 结 果 如 图 2.15 所 示 。 
1421739525 输出 日 期 201 


1399219200 输出 日 


距 2014 年 5 月 5 日 已 过 去 . 


图 2.15 ”比较 两 个 时 间 戳 的 大 小 


图 关键 技术 


本 实例 主要 是 通过 利用 strtotime0 函 数 将 时 间 转 换 为 UNIX 时 间 戳 ， 再 进行 相关 取 整 运算 而 实现 的 ， 其 中 涉 
及 的 相关 函数 语法 如 下 : 

(1) strtotime() 函 数 。 该 函数 预期 接受 一 个 包含 英文 日 期 格式 的 字符 串 ， 并 尝试 将 其 解析 为 UNIX 时 间 戳 : 

int strtotime( string time [, int now]); 

strtotime() 函 数 有 两 个 参数 。 如 果 参 数 time 的 格式 是 绝对 时 间 ， 则 now 参数 不 起 作用 ; 如 果 参 数 time 的 格 
式 是 相对 时 间 ， 其 对 应 的 时 间 由 参数 now 来 提供 ， 若 没有 提供 参数 now， 则 其 对 应 的 时 间 为 当前 时 间 。 如 果 解 
析 失 败 ， 则 返回 FALSE。 在 PHP 5.1.0 之 前 的 版 本 中 ， 本 函数 在 失败 时 返回 -1。 
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(2) ceil0 函 数 。 该 函数 返回 不 小 于 value 的 下 一 个 整数 : 


float ceil ( float value); 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 首 先 对 PHP 语言 中 的 时 区 进行 设置 ， 将 时 区 更 改 为 中 国 上 海 时 区 。 然 后 ， 通 过 
strtotime0 〇 函数 获取 当前 时 间 的 UNIX 时 间 戳 ， 并 与 指定 的 时 间 戳 进行 算术 和 运算。 最后， 将 时 间 戳 运算 结果 转换 
为 天 数 ， 并 通过 ceil0 函 数 进 行 取 整 运算 ， 然 后 输出 结果 ， 其 代码 如 下 : 

<?php 


date_default_timezone set("Asia/ShangHai"): // 将 格林 威 治 时 间 设 置 为 本 地 时 间 
$a = strtotime("now"); // 取 得 当前 时 间 截 
$b = strtotime("05 May 2014"); /取得 2014 年 5 月 5 日 的 时 间 戳 
echo Sa 
echo "输出 日 期 ".date("Y-m-d H:i:s",$a)."<br><br>"; // 取 得 以 $a 为 时 间 点 的 时 间 
echo $b."\n"; 
echo "输出 日 期 ".date("Y-m-d H:i:s",$b)."<br><br>"; // 取 得 以 $b 为 时 间 点 的 时 间 
$c = ceil(($a - $b)/(3600*24)): /计算 相差 天 数 
echo " 距 2014 年 5 月 5 日 已 过 去 "$c" 天 "; 
> 
(2) 将 该 文件 存储 于 \MR\02\046 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.15 所 示 。 
秘笈 心 法 


心 法 领悟 046: 时 间 戳 的 相关 说 明 。 

有 效 的 时 间 戳 的 范围 通常 从 Fri, 13 Dec 1901 20:45:54 GMT 到 Tue, 19 Jan 2038 03:14:07 GMT (对 应 于 32 位 
有 符号 整数 的 最 小 值 和 最 大 值 ) 。 不 是 所 有 的 平台 都 支持 负 的 时 间 戳 ,因此 日 期 范围 就 被 限制 为 不 能 早 于 UNIX 
纪元 。 这 意味 着 在 1970 年 1 月 1 日 之 前 的 日 期 将 不 能 用 在 Windows、 一 些 Linux 版 本 以 及 几 个 其 他 的 操作 系 
统 中 。 


<4 拉 注意 : 在 UNIX 系统 中 ， 日 期 与 时 间 表 示 为 自 1970 年 1 月 1 日 零点 起 到 当前 时 刻 的 秒 数 ， 这 种 时 间 称 为 
UNIX 时 间 蕉 ， 用 32 位 二 进 制 表示 。 其 中 ，1970 年 1 月 1 日 零点 称 为 UNIX 世纪 元 。UNIX 时 间 戳 
提供 了 一 种 统一 、 简 洁 的 时 间 表示 方式 ， 在 不 同 的 操作 系统 中 均 受 到 支持 ， 同 一 时 间 在 UNIX 和 
Windows 中 均 以 相同 的 UNIX 时 间 戳 表示 ， 所 以 不 需要 在 不 同 的 系统 中 进行 转换 。 同 时 ，UNIX 时 
间 稚 是 一 个 时 间 差 ， 与 时 区 没有 关系 ， 无 论 当前 PHP 中 使 用 的 是 何 种 时 区 ， 其 UNIX 时 间 惟 是 唯 


一 的 。 
六 高 级 | 
实例 047 趣味 指数 : ooholodl| 


力 实例 说 明 


条 件 运算 符 用 于 执行 或 真 或 假 运算 。 本 实例 演示 如 何 用 三 元 运算 符 判断 数字 的 奇偶 性 , 运行 结果 如 图 2.16 
所 示 。 


0 是 偶数 1 是 奇数 3 是 奇数 
5 是 奇数 6 是 偶数 8 是 偶数 9 是 奇数 


2.16 用 三 元 运算 符 判断 数字 的 奇偶 性 
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图 关键 技术 


本 实例 使 用 三 元 运算 符 判断 数字 的 奇偶 性 ， 并 且 在 判断 数字 奇偶 性 时 使 用 了 求 余 运算 符 。 当 期 望 数 字 与 数 
字 2 做 除法 运算 时 ， 如 果 存 在 余数 即 不 能 被 2 整除 ， 为 奇数 ， 否 则 为 偶数 。 三 元 运算 符 的 语法 如 下 : 


(expr) ? {statementl;} : {statement2;} 


三 元 运算 符 与 和 f..else... 语 句 实现 的 功能 完全 相同 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 ， 通 过 for 循环 语句 循环 输出 0~9 的 10 个 数字 。 然 后 ， 将 得 到 的 10 个 数字 


分 别 与 2 做 求 余 运算 并 将 运算 结果 作为 三 元 运算 的 条 件 进 行 判断 。 最 后 ， 将 判断 的 结果 利用 echo 语句 输出 ， 其 
代码 如 下 : 


< 
/做 小 于 10 的 循环 
for($a = 0:Sa < 10:Sat++jf 
// 用 三 元 运算 输出 ， 如 果 没 有 余数 则 是 偶数 ， 否 则 为 奇数 
echo $a%2==0? $a." 是 偶数 "."\n" :$a." 是 奇数 "."n"; 


} 
> 


(2) 将 该 文件 存储 于 \MR\02\047 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.16 所 示 。 
力 秘笈 心 法 


心 法 领悟 047: 用 让 ..else.… 语 句 实现 实例 。 
三 元 运算 等 同 于 if...else... 语 句 ， 下 面 通过 if...else... 语 句 实现 本 实例 ， 其 语法 如 下 : 


<?php 
/做 小 于 10 的 循环 
for($a = 0:$a < 10:$at+){ 
/用 站..else… 语 句 实现 
Sb=0; 


if($a% 2 —0){ 
// 设 定 条 件 ， 让 $a 与 2 做 求 余 运算 
echo "Sa" 是 偶数 
jakef 
ccho "San 是 奇数 ; 
} 
} 
?> 
级 | 
实例 048 高 | 
实例 起 叶 指 娄 ， blll 


力 实例 说 明 


逻辑 运算 符 往往 作为 ff 等 语句 的 条 件 出 现 。 逻 辑 运 算 符 有 很 多 种 而 且 功 能 各 不 相同 。 本 实例 介绍 逻辑 运算 
符 的 语法 等 相关 知识 , 并 通过 逻辑 运算 符 来 演示 用 户 是 否 具 有 后 台 管理 权限 , 运 各 外 直 系 闻 轩 2.17 和 图 2.18 所 示 。 


图 2.17 具有 后 台 管 理 权限 图 2.18 不 具有 后 台 管理 权限 
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图 关键 技术 


本 实例 主要 是 通过 逻辑 运算 符 && (逻辑 与 ) ， 将 从 表单 中 利用 POST 方法 取得 的 由 文本 框 输入 的 用 户 名 和 
密码 联系 起 来 。 用 户 名 和 密码 必须 同时 为 真 ， 让 语句 的 结果 才 会 为 真 ， 反 之 为 假 。 
力 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 首 先 ， 编 写 form 表单 ， 将 表单 中 的 method 方法 定义 为 POST。 然后 ， 当 单 击 按 
钮 时 ， 将 POST 方法 接收 的 用 户 名 和 密码 进行 逻辑 与 运算 。 当 站 语 句 的 结果 为 TRUE 时 ， 输 出 “您 具有 管理 员 
权限 ”的 提示 ， 和 否则 输出 “您 非 权 限 用 户 ” 的 提示 ， 其 代码 如 下 : 

Ce echo "<form action="method=!post>"; /| 输出 表单 

echo "用 户 名 : <input type='text name='text><br>"; 


echo " 密 &nbsp:&nbsp: 码 : <input type= password name=pwd>"; 
echo "<input type='submit name='sub' value= 确 定 >"; 


echo "</form>"; 
ifS_POST[sub]){ /通过 POST 方式 提交 
if($_POST[text] 一 "mr" && $_POST[pwd] 一 "mrsoft"){ /验证 用 户 名 和 密码 
echo "<script>alert( 您 具有 管理 员 权限 ):</script>": /符合 条 件 输出 提示 
jelsef 
echo "<script>alert( 您 非 权 限 用 户 ):</script>"; // 不 符合 条 件 输出 提示 


} 
} 


> 


(2) 将 该 文件 存储 于 \MR\02\048 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.17 和 图 2.18 所 示 。 
国 秘笈 心 ; 
心 法 领悟 048: 使 用 优先 级 的 小 技巧 。 


如 果 在 涉及 运算 符 的 优先 级 时 不 想 总 查找 优先 级 表 而 本 身 又 记忆 不 清 的 话 ， 建 议 使 用 小 括号 把 想 要 先 运算 
的 表达 式 括 起 来 ， 这 样 问题 就 迎刃而解 了 。 


实例 049 


力 实例 说 明 


在 应 用 字符 串 时 往往 需要 将 两 个 字符 串 进行 连接 ， 这 时 可 以 使 用 字符 串 运算 符 。 本 实例 使 用 字符 串 运算 符 
打印 随机 组 合生 日 祝福 语 ， 运 行 结果 如 图 2.19 所 示 。 


生日 快乐 祝 你 方 事 刀 意 | 


2.19 打印 随机 组 合生 日 祝福 语 


图 关键 技术 


字符 串 可 以 用 “.” (点 ) 字符 串 连接 符 连 接 ， 该 连接 符 可 以 把 两 个 或 两 个 以 上 字符 串 连 接 成 一 个 新 的 字符 
串 。 字 符 串 的 连接 有 两 种 形式 ， 第 一 种 是 连接 运算 符 “.”; 第 二 种 是 连接 赋值 运算 符 “.=”。 在 实际 的 程序 开 
发 中 ， 这 两 种 连接 方式 都 很 常用 。 


力 设计 过 程 
创建 ndex php 文件 ， 首 先 ， 定 义 两 个 数组 ， 将 字符 串 信息 保存 在 数组 中 。 然 后 ， 利 用 rand0 函 数 随机 取得 
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数组 中 的 两 条 信息 并 保存 在 变量 中 。 最 后 ， 通 过 echo 语句 输出 用 连接 运算 符 连 接 的 变量 ， 其 代码 如 下 : 
<2pl 


hp 
$arr =array(" 生 日 快乐 "," 今 天 是 你 的 出 生日 "." 同 学 们 为 你 许愿 "); /定义 数组 
$array = array(" 视 你 万 事 如 意 "," 祝 你 生日 快乐 "." 祝 你 福 如 东海 长 流水 寿 比 南山 不 老 松 "); 。 // 定 义 数 组 
Srand = rand(0.2); /定义 随机 数 
echo $arr[Srand].Sarray[$rand]; /输出 字符 串 
?> 
图 秘笈 心 法 


心 法 领悟 049: “+” 号 的 相关 说 明 。 
使 用 过 C 或 Java 语言 的 读者 应 该 注意 ， 这 里 的 “+” 号 ， 只 做 算术 运算 符 使 用 ， 而 不 能 做 字符 串 运 算 符 。 


高 级 | 
| 


实例 050 六 中 六 友信 信人 娘 


力 实例 说 明 
在 PHP 语言 中 ， 为 了 提升 编程 效率 设置 了 一 些 自 增 自 减 运算 符 ， 这 些 运算 符 在 循环 语句 中 得 到 广泛 应 用 。 
本 实例 简要 介绍 自 增 自 减 运算 符 ， 并 通过 自 增 自 减 运算 符 修饰 的 变量 来 演示 其 应 用 ， 运 行 结果 如 图 2.20 所 示 。 


2000 2004% 2003 20160 202( 
图 2.20 打印 2000~2020 年 间 的 所 有 半年 


图 关键 技术 


递增 或 递减 运算 符 有 两 种 使 用 方法 ， 一 种 是 先 将 变量 增加 或 减少 1 后 再 将 值 赋 给 原 变量 ， 称 为 前 置 递增 或 
递减 运算 符 〈 也 称 前 置 自 增 自 减 运算 符 ) ; 另 一 种 是 将 运算 符 放 在 变量 后 面 ， 即 先 返 回 变 量 的 当前 值 ， 然 后 变 
量 的 当前 值 增加 或 减少 1， 称 为 后 置 递 增 或 递减 运算 符 〈 也 称 后 置 自 增 自 减 运算 符 ) 。 本 实例 将 递增 或 递减 运 
算 符 应 用 到 for 循环 的 变量 中 ， 利 用 变量 的 变化 完成 期 望 次 数 的 循环 。 


图 设计 过 程 
创建 index.php 文件 ， 首 先 ， 利 用 for 循环 定义 循环 变量 ， 将 变量 的 初始 值 设置 为 2000， 最 大 值 小 于 2020， 


并 且 要 求 变量 做 自 增 运算 。 然 后 ， 设 置 循环 变量 与 4 做 求 余 运算 。 最 后 ， 把 符合 条 件 的 数值 通过 echo 语句 输出 ， 
代码 如 下 : 


<?php 
if$_ POST[sub]){ /通过 POST 接收 参数 
for($a = 2000:$a <= 2020:$at+){ // 通 过 循环 定义 循环 变量 
if($a% 4=— 0){ // 将 循环 变量 与 4 做 求 余 运算 
echo $a."&nbsp:&nbsp:": /输出 循环 变量 
} 
} 
} 
> 
图 秘笈 心 法 


心 法 领悟 050: 自 增 自 减 运算 符 。 
自 增 自 减 运算 符 在 PHP 循环 结构 中 ， 特 别 是 for 循环 结构 中 有 着 非常 重要 的 地 位 。 至 于 自 增 自 减 运算 符 前 
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置 和 后 置 的 区 别 ， 请 详 见 实例 051 。 


实例 051 


力 实例 说 明 
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前 置 运 算 符 与 后 置 运算 符 的 应 用 方向 与 实例 050 相同 ， 大 多 用 在 循环 语句 中 。 本 实例 应 用 自 增 自 减 运算 符 
来 修饰 变量 ， 通 过 显示 结果 来 说 明 前 置 运 算 符 与 后 置 运算 符 的 区 别 ， 运 行 结 果 如 图 2.21 所 示 。 


-| 后 置 加 证 算 -…- 
012345678910 
~ 前 甘 加 运算 
1234567891011 


~ 前 置 减 运 算 - 广 -二 


987654321gMC 人 


| 后 轩 需 运算 …-- 
109876543210 


图 2.21 前 置 运算 符 与 后 置 运算 符 的 区 别 


图 关键 技术 


本 实例 的 关键 点 是 自 增 自 减 运算 符 的 灵活 运用 ， 相 关 说 明 详 见 实例 050。 在 使 用 前 置 减 运算 符 时 ， 要 注意 


给 定 的 初始 值 ， 
力 设计 过 程 


否则 会 出 现 本 例 的 问题 ， 即 前 置 减 运算 输出 负数 。 


(1) 创建 PHP 脚本 文件 ， 首 先 通过 for 循环 语句 定义 循环 变量 ， 然 后 通过 echo 语句 输出 循环 变量 ， 其 代 


和 


后 置 加 运算 
for($b= 0;$b <= 10:$Sb++){ 
echo Satt." "; 


echo "<br>--- 一 -一 前 置 加 运算 -一 一 一 <br>"; 


$d=0; 
for(Sb = 0:Sb < 10; 2 
echo ++$d. 


} 
echo 人生 本 下 全 


$f=10: 
for($b = 10:$b >= 0:$b--){ 


echo "<br>----—-- 后 置 减 运算 -<br>"; 


Sg =10: 

for($b = 10:Sb >= 0:$b-){ 
echo Sg—" "; 

} 


?> 


// 自 定义 变量 并 给 定 初始 值 


// 使 用 for 循环 语句 
// 使 用 后 置 运 算 符 


// 使 用 前 置 运 算 符 


// 使 用 前 置 运 算 符 


// 使 用 后 置 运 算 符 


(2) 将 该 文件 存储 于 \MR\02\051 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.21 所 示 。 


国 秘笈 心 法 


心 法 领悟 051: 前 置 运 算 符 与 后 置 运算 符 。 
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前 置 运算 符 是 在 程序 第 一 次 运行 时 就 进行 自 增 或 自 减 运算 ， 而 后 置 运算 符 是 在 程序 运行 完 一 次 之 后 再 进行 
自 增 或 自 减 运算 。 


实例 052 字 进 行 加 密 和 解密 高 级 


趣味 指数 : 伍 食 食 伍 1 


有 on eas sds on ns on eo ron dror nor erredr endo edad dor te0 rrr J 


力 实例 说 明 
位 运算 符 也 是 PHP 运算 符 中 不 可 或 缺 的 一 种 。 本 实例 通过 位 运算 符 实现 对 数字 进行 加 密 和 和 解密， 运行 结果 


如 图 2.22 和 图 2.23 所 示 。 


数字 口令 绰 111 [ 确定 | i 一 
证 泌 解 窗口 令 111 
图 2.22 使 用 位 运算 符 对 数字 进行 加 密 图 2.23 ”使 用 位 运算 符 对 数字 进行 解密 
图 关键 技术 


位 运算 符 是 指 对 二 进 制 位 从 低 到 高 位 对 齐 后 进行 运算 ，PHP 中 的 位 运算 符 如 表 2.6 所 示 。 本 实例 中 ， 利 用 
自 定义 函数 将 文本 框 信息 与 定义 的 常量 做 指定 的 位 运算 ， 并 返回 计算 结果 ， 从 而 将 文本 框 信息 进行 加 密 或 解密 
处 理 。 


表 2.6 位 运算 符 


举例 
Sm&sn 
Sml$n 
3$m^$n 
Sm~$n 
$m<<$n 
$m>>$n 


力 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 ， 编 写 form 表单 并 定义 常量 ， 将 数值 “3.1415926” 赋 给 常量 PL。 然 后 ， 定 


义 自 定义 函数 ， 在 函数 体内 部 ， 将 文本 框 信息 与 常量 PI 做 移 位 运算 并 返回 结果 。 最 后 ， 通 过 提交 数据 和 单 击 按 
钮 实现 输出 加 密 、 解 密 算法 的 结果 ， 其 代码 如 下 : 
<2php 


/定义 表单 

echo "<form action=" method='post>": 

echo "数字 口令 : <input name='text type='text>"; 

echo "<input type='submit’ name='sub' valuc= 确 定 >"; 

echo "</form>"; 

define("PI".3.1415926): /定义 常量 

function Enerypt($str){ // 自 定义 加 密 算法 
Tetum $str = $str << PI: 

} 

function Decrypt($st){ // 自 定义 解密 算法 
Tetum $str = $str >> PT: 

1 

if($_POST[sub){ // 通 过 POST 方式 传 参 
echo "加 密 口 令 &nbsp:&nbsp:".Encrypt($_POST[text])."<br>": /输出 口令 
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$_SESSION[pwd] = Encrypt($ POST[text): // 将 口令 保存 在 SESSION 中 
> 
<a href='index.php?pwd=1> 解 密 口令 </a> // 超 链接 
<php 
iflisset($_GET[pwd]){ 1/ 判断 地 址 栏 是 否 存 在 此 参数 
echo "解密 口令 &nbsp;&nbsp;".Decrypt($_SESSION[pwd]); // 输 出 解密 结果 


} 

(2) 将 该 文件 存储 于 \MR\02\052 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.22 和 图 2.23 所 示 。 

心 法 领悟 052: 位 运算 符 的 相关 说 明 。 

位 运算 符 允 许 对 整 型 数据 中 指定 的 位 进行 置 位 。 如 果 左 右 参数 都 是 字符 串 ， 则 位 运算 符 将 操作 字符 的 
ASCII 值 。 


23 包含 语句 


引用 外 部 文件 可 以 减少 代码 的 重用 性 ， 是 PHP 编程 的 重要 技巧 。PHP 提供 了 4 个 非常 简单 有 用 的 语句 ， 它 
们 允许 重新 使 用 任何 类 型 的 代码 。 使 用 任意 一 个 语句 均 可 以 将 一 个 文件 载 入 PHP 脚本 中 ， 为 网 站 创建 统一 风格 
的 页 面 ， 从 而 更 加 轻松 地 编写 和 维护 代码 。 


实例 说 明 


当 需 要 在 文件 外 部 引入 新 文件 时 就 要 借助 include 或 require 等 包含 语句 。 本 实例 通过 require 包含 语句 实现 
代码 重用 ， 运 行 结果 如 图 2.24 所 示 。 


| 
高 级 | 
趣味 指数 : 傅 塘 请 计 


汽车 在 公路 上 行 强 , 不 一 会 后 面 来 了 -条 
ee 下 下 了 ， A 


四 2.24 提高 代码 重用 率 


图 关键 技术 


本 实例 通过 require 语句 包含 并 运行 指定 文件 。 PHP 文件 被 执行 之 前 ，PHP 解析 器 会 用 被 引用 文件 的 全 部 内 
容 蔡 换 require 语句 ， 然 后 与 require 语句 之 外 的 其 他 语句 组 成 新 的 PHP 文件 。 最 后 再 按 新 的 PHP 文件 执行 程序 
代码 ， 其 语法 如 下 : 

void require(string filename): 


和 el 
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参数 说 明 : 
filename: 是 指定 的 完整 路 径 文件 名 。 


力 设计 过 程 
(1) 创建 ne php 文件 ， 建 立 两 个 字符 串 表达 式 ， 代 码 如 下 : 
hp 


pl 
$strl =" 大 连 是 一 个 美丽 的 地 方 ， 它 三 面 环 海 ， // 声 明 两 个 字符 串 变量 

背 依 大 山 ， 就 像 一 个 乘风破浪 的 水 手 , 

就 算 再 大 的 风浪 ， 也 依然 昂首 挺 胸 不 届 不 挠 "; 

$str2 = "一 天 ， 老 杨 开 着 自己 的 奥拓 小 汽车 在 公路 上 行驶 ， 不 一 会 后 面 来 了 一 辆 大 奔 。 

大 奔 司 机 冲 着 老 杨 说 : “哥们 ， 开 过 大 奔 吗 ? ”然后 哦 一 下 开 走 了 ， 老 杨 很 生气 ， 心 想 

开 大 奔 就 牛 吗 ， 然 后 加 大 油门 ， 赶 上 了 大 奔 ， 大 奔 司 机 又 问 : “哥们 ， 开 过 大 奔 吗 ?” 然 后 哦 一 下 

开 走 了 ， 老 杨 再 也 排 不 上 了 。 只 能 生 着 闷气 地 向 前 开 着 ， 过 了 一 会 ， 路 边 翻 着 一 辆 大 奔 ， 司 机 被 压 在 车 下 ， 
看 见 老 杨 开 车 过 来 ， 就 带 着 哭 腔 说 : “老大 。。。 你 开 过 大 奔 吗 。。。 和 刹车 在 哪 啊 ? ”"; 

> 


(2) 创建 index.php 文件 ， 通 过 require 语句 包含 文件 inc.php， 代 码 如 下 : 


php 
require("inc. php"); 
switch($_GET[link]){ // 接 收 地 址 栏 的 值 
case "我 的 家 乡 "; // 如 果 值 等 于 “我 的 家 乡 ” 
echo Sstrl; // 输 出 字符 串 1 
break: /停止 执行 语句 
case "幽默 笑话 "; /如 果 值 等 于 “幽默 笑话 ” 
echo $str2; /输出 字符 串 2 
rs /停止 执行 语句 
> E 
力 秘笈 心 法 


心 法 领悟 053: 使 用 require 语句 的 注意 事项 。 
因为 使 用 require 语句 相当 于 将 另 一 个 源 文件 的 内 容 完全 复制 到 本 文件 中 ,所 以 一 般 将 该 语句 放 在 源 文件 的 
起 始 位 置 ， 用 于 引用 需要 使 用 的 公共 函数 和 公共 类 文件 等 。 


力 实例 说 明 


一 个 程序 可 能 要 与 数据 库 多 次 交互 ， 所 以 数据 库 连接 信息 要 单独 保存 在 某 一 文件 中 ， 这 也 是 代码 重用 的 一 
种 体现 。 本 实例 通过 include 语句 包含 数据 库 文件 ， 运 行 结果 如 图 2.25 所 示 。 


编号 ，1 姓名 : 杨 明 


高 级 | 
趣味 指数 : 友 克 克 页 ， 


编号 ，6 姓名 , 刘 员 华 ， 
图 2.25 包含 数据 库 连 接 文件 


图 关键 技术 


include 语句 与 require 语句 在 作用 上 是 完全 相同 的 ， 但 是 使 用 include 语句 引用 外 部 文件 时 ， 只 有 代码 执行 
到 该 语句 时 才 将 外 部 文件 引用 进来 并 读 取 文件 的 内 容 ， 当 所 引用 的 外 部 文件 发 生 错 误 时 ， 系 统 只 给 出 一 个 警告 ， 


PHP 开发 实例 大 全 (基础 卷 ) 
整个 PHP 文件 则 继续 向 下 执行 。include 语句 的 语法 如 下 : 


void include(string filename): 
参数 说 明 : 
filename: 是 指定 的 完整 路 径 文件 名 。 
力 设计 过 程 
(1) 创建 index.php 文件 ， 通 过 include 语句 包含 数据 库 文件 ， 并 执行 查询 操作 输出 结果 ， 其 代码 如 下 : 
让 ("inc.php"); // 包 含 数据 库 连接 文件 
$sql = "select * from tb_include"; /SQL 语句 
S$rs = mysql query($sq]); /执行 查询 操作 
while($rst = mysql fetch_array($rs)){ // 将 查询 结果 循环 输出 


echo 编号 ，'Srst[0],&nbsp:&nbsp: 姓 名 : "Srst[1]."<br>": 


?> 
人 创建 数据 库 连 接 文件 inc.php， 其 代码 如 下 : 


Re mysql_connect("localhost", "root","111"): /连接 MySQL 
mysql_select_db("db_database02",$conn); // 连 接 数据 库 
mysql_query("SET NAMES GBK"); /设置 编码 格式 
> 

力 秘笈 心 法 


心 法 领悟 054: 使 用 include 语句 的 注意 事项 。 
include 语句 包含 一 个 不 存在 的 文件 时 会 产生 警告 。 


力 实例 说 明 
在 设计 网 站 的 过 程 中 往往 都 是 先 用 <table> 或 <div> 标 签 将 整个 网 站 进行 布局 ， 然 后 通过 include_once 等 语句 
将 各 部 分 内 容 包含 进来 。 本 实例 介绍 使 用 include_once 语句 包含 网 站 头 文件 ， 运 行 结果 如 图 2.26 所 示 。 


| 
高 级 | 
起 呆 指 数 帘 贾 页 寅 wx 


2.26 包含 网 站 头 文件 


图 关键 技术 


PHP 程序 开发 中 ， 在 使 用 include_once 语句 时 ， 应 该 明确 其 与 mclude 语句 的 区 别 。include_once 语句 会 在 
导入 文件 前 检测 该 文件 是 否 在 该 页 面 的 其 他 部 分 被 引用 过 ， 如 果 有 ， 则 不 会 重复 引用 该 文件 ， 即 程序 只 引用 一 
次 。 例 如 ， 要 导入 的 文件 中 存在 一 些 自 定义 函数 ， 如 果 在 同一 个 程序 中 重复 导入 这 个 文件 ， 在 第 二 次 导入 时 便 
会 发 生 错误 ， 因 为 PHP 不 允许 相同 名 称 的 函数 被 重复 声明 。 
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图 设计 过 程 

(1) 创建 index.php 文件 ， 通 过 include_once 语句 包含 文件 inc.php， 其 代码 如 下 : 

<table><tr><td><?php include_once("inc .php"):?></td></tr></table> // 在 table 标签 中 嵌入 PHP 包含 语句 
(2) 创建 inc.php 文件 ， 将 图 片 作为 <body> 标 签 的 背景 图 ， 其 代码 如 下 : 

<title> 包 含 头 文件 </title> 

<body background=". /image/1 jpg" style="font-size:14px; color:#000099; font-family:' 微 软 雅 黑 "> 。” // 背 景 

<img sre="image/1.jpg"> /1/ 引 入 图 片 

<body> 
(3) 运行 本 实例 ， 运 行 结果 如 图 2.26 所 示 。 

秘笈 心 法 


心 法 领悟 055: 使 用 include_once 语句 的 注意 事项 。 
include_once 语句 应 用 于 在 脚本 执行 期 间 同 一 个 文件 有 可 能 被 包含 超过 一 次 的 情况 下 , 确保 指定 文件 只 被 包 
会 一 次 ， 从 而 避免 函数 重复 定义 ， 变 量 重新 赋值 。 


起 味 指数 : 贾 机 页 页 | 


实例 056 


国 实例 说 明 
require 语句 和 include 语句 在 作用 上 没有 本 质 区 别 , 用 户 可 根据 个 人 习惯 选择 使 用 。 本 实例 通过 使 用 require 


语句 包含 网 站 尾 文件 ， 运 行 结果 如 图 2.27 所 示 。 
ss 


ant 二 区 


| 


2.27 包含 网 站 尾 文件 


力 关键 技术 
本 实例 的 关键 点 是 rerquire 语句 的 运用 。require 语句 的 详细 说 明 请 参见 实例 053。 
力 设计 过 程 
(1) 创建 index.php 文件 ， 编 写 PHP 标记 ， 通 过 require 语句 包含 文件 inc.php， 其 代码 如 下 : 
ravinephp); /包含 尾 文件 


多 
(2) 创建 nc.php 文件 , 定义 网 站 尾 文件 , 利用 <p> 标 签 将 明日 科技 公司 的 相关 信息 包含 进来 , 其 代码 如 下 : 
<table width="800" height="129" border="1" bordercolor="#CCCCCC" bordercolorlight="#CCCCCC" cellspacing="0"> 
> 
7 width="800"><div align="center"> /定义 表格 
<p> 长 春 市 明日 科技 有 限 公司 </p> 
<p> 电 话 : 0431-84978981</p> 
<p> 传 真 : 0431-84978981</p> 
<p>email:www.mrsoft.com</p> 
<ldiv><ltd> 
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<ftr> 
</table> 


(3) 运行 本 实例 ， 运 行 结果 如 图 2.27 所 示 。 


心 法 领悟 056: 使 用 require 语句 的 注意 事项 。 
require 语句 包含 不 存在 的 文件 时 会 出 现 一 个 致命 错误 。 


高 级 : 
起 叶 指示: 裕 友 机 页 


实例 057 


力 实例 说 明 


- 记 估 时 糙 圩 州 ” 加 次 内 攻 湾 队 痢 ~ 
介入 ” 蝴 冯 市 隐 戎 若 雹 ”证 加 本 台 
有 ”加 妥 刘 两 炎 届 其 ” 滑 |r 州 关 种 


图 2.28 包含 网 站 主 文件 


力 关键 技术 


require_once 语句 是 require 语句 的 延伸 ， 其 功能 与 require 语句 基本 类 似 ， 不 同 的 是 在 应 用 require_once 语 
句 时 会 先 检查 要 引用 的 文件 是 不 是 已 经 在 该 程序 中 的 其 他 地 方 被 引用 过 , 如 果 有 , 则 不 再 重复 调用 该 文件 .例如 ， 
同时 应 用 require_once 语句 在 同一 个 页 面 中 引用 了 两 个 相同 文件 ， 那 么 在 输出 时 只 有 第 一 个 文件 被 执行 ， 第 二 
次 引用 的 文件 不 会 被 执行 。 


图 设计 过 程 
(1) 创建 index.php 文件 ， 通 过 switch 语句 接收 地 址 栏 传递 的 参数 ， 根 据 参数 传递 的 数据 引入 通过 
Tequire_once 语句 包含 的 文件 ， 其 代码 如 下 : 


<?php 
switch($_GET[link]){ /通过 GET 方式 接收 地 址 栏 参数 
case "首页 ": 
require_once(inc.php"); /包含 文件 inc.php 
break: 
case "注册 ” 
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require_once('ine_1.php): // 包 含 文件 inc_1.php 
break: 
case "浏览 ": 
require_once(inc_ 2.php); /包含 文件 inc 2.php 
break: 
default: 
inelude(inephp): 


} 
> 


(2) 运行 本 实例 ， 运 行 结果 如 图 2.28 所 示 。 


心 法 领悟 057: 使 用 require_once 语句 的 注意 事项 。 
require_once 语句 与 require 语句 一 样 ， 当 包含 不 存在 的 文件 时 ， 会 出 现 一 个 致命 错误 。 


2.4 条 件 语句 


条 件 控制 语句 就 是 以 一 定 的 条 件 作 为 依据 ， 根 据 判 断 的 结果 确定 执行 哪 一 部 分 代码 ， 而 不 执行 与 该 部 分 代 
码 并 列 的 其 他 代码 。 

在 PHP 中， 条 件 控制 语句 可 分 为 以 下 两 种 类 型 : 

回 这 条 件 控制 语句 。 

加 ”switch...case 分 支 控制 语句 。 


图 实例 说 明 


在 PHP 应 用 中 ， 类 似 生日 提醒 等 功能 的 程序 随处 可 见 ， 主 要 是 因为 这 样 的 程序 有 一 定 的 定时 效果 。 本 实例 
通过 站 语句 和 foreach 循环 语句 实现 一 个 员工 生日 提醒 的 小 程序 ， 如 图 2.29 所 示 。 


图 2.29 员工 生日 提醒 


力 关键 技术 


本 实例 的 关键 点 是 利用 让 条 件 语句 ， 将 文本 框 中 的 日 期 与 数组 中 员工 生日 日 期 进行 比较 。 
(1) foreach 语句 


foreach 语句 仅 能 用 于 数组 ， 当 试图 将 其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。 


foreach (array_expression as $value) statement: 


参数 array 表示 要 遍历 的 数组 ，expression 表示 键 值 ，$value 表示 键 值 的 对 应 值 ，statement 表示 语句 块 。 
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(2) 站 语句 

让 语句 对 某 段 程序 的 执行 附加 一 个 条 件 ， 如 果 条 件 成 立 ， 就 执行 这 段 程序 ， 否 则 跳 过 这 段 程序 。 

这 expD statement; 

参数 expr 表示 判定 条 件 ，statement 表示 语句 块 。 

(3) array0 函 数 

arrayO 函 数 返 回 根据 参数 建立 的 数组 。 参 数 可 以 用 => 运算 符 给 出 索引 。 

amay array ( [mixed ..)); 
图 设计 过 程 

(1) 创建 index.php 文件 。 首 先 ， 根据 数 组 的 特点 将 键 值 与 对 应 值 存储 在 数组 中 ， 然后， 利用 foreach 语句 
遍历 数组 ， 将 取得 的 value 值 与 当前 日 期 进行 比较 。 最 后 ， 将 符合 条 件 的 值 进行 输出 ， 其 代码 如 下 : 


<?php 
$a = array(" 小 杨 "=>"05 月 30 日 "," 小 王 "=>"05 月 28 日 "," 小 张 "=>"05 月 29 日 "); // 定 义 数 组 
foreach($a as $key => $value){ // 用 foreach 语句 循环 数组 
if(date("m 月 d 日 ") 一 $value){ /用 让 条 件 语句 进行 比较 
echo "&nbsp;&nbsp; 今 天 是 ".Skey." 的 生日 ": /输出 结果 
} 
} 
> 
(2) 运行 本 实例 ， 运 行 结果 如 图 2.29 所 示 。 
秘笈 心 法 


心 法 领悟 058: 使 用 foreach 语句 的 相关 说 明 。 
foreach 语句 所 操作 的 数据 是 指定 数组 的 一 个 副本 ， 而 不 是 该 数组 本 身 。 因 此 数组 指针 不 会 被 foreach 结构 


改变 ， 对 返回 的 数组 单元 的 修改 也 不 会 影响 源 数组 ， 不 过 源 数组 的 内 部 指针 的 确 在 处 理 数组 的 过 程 中 向 前 移动 
了 。 假定 foreach 循环 运行 到 结束 ， 源 数组 的 内 部 指针 将 指向 数组 的 结尾 。foreach 语句 不 支持 用 “@” 来 禁止 错 
误 信息 。 
高 级 | 
实 斧 
实例 059 趣味 指数 : 妇女 妇女 
图 实例 说 明 


本 实例 通过 让 条 件 语句 对 文本 框 中 输入 的 考试 成 绩 进 行 评定 和 选择 ， 运 行 结果 如 图 2.30 所 示 。 


办 六 考试 成 绩 ,|100 E23 
成 绩优 秀 上 


图 2.30 考试 成 绩 评定 标准 


图 关键 技术 


让 语句 是 最 简单 的 条 件 判断 语句 ， 它 对 某 段 程序 的 执行 附加 一 个 条 件 ， 如 果 条 件 成 立 ， 就 执行 这 段 程序 ; 
否则 跳 过 这 段 程序 ， 执 行 下 面 的 程序 。 

本 实例 的 关键 点 是 让 语句 的 灵活 运用 。 当 expr 的 值 为 TRUE 时 ， 执 行 statementl 语句 。 

这 expnjfstatementl3 

参数 说 明 : 

expr: 条 件 判断 语句 。 
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符合 条 件 的 执行 代码 。 
图 设计 过 程 


创建 index.php 文件 ， 当 单 击 “ 评 定 ”按钮 时 ， 程 序 自动 利用 POST 方法 接收 数据 ， 并 且 利用 站 语句 对 接收 
的 数据 进行 判断 ， 再 用 echo 语句 输出 结果 ， 其 代码 如 下 : 


statement: 


hp 
if($_POST[sub]){ 


/通过 POST 方式 传递 参数 
if($_POST[text] 一 100){ // 当 成 绩 为 100 时 
echo "成 绩优 秀 ": /输出 
if($_POST[text] >= 60 and$_ POST[text] < 100){ // 当 成 绩 大 于 等 于 60 小 于 100 时 
echo "成 绩 良 好 "; /输出 
if($_POST[text] < 60){ // 当 成 绩 小 于 60 时 
"不 及 格 ": /输出 
} 
> 
图 秘笈 心 ; 
心 法 领悟 059: 让 语句 的 变 体 。 


让 语句 有 多 种 变 体 ， 因 此 其 应 用 范围 非常 广泛 ， 


力 实例 说 明 


用 户 在 浏览 一 些 网 站 时 ， 网 站 本 身 会 将 用 户 定义 为 VIP 会 员 或 者 游客 ， 会 员 可 以 享有 更 多 的 权限 ， 而 游客 
对 网 站 的 浏览 有 权限 限制 ， 下 面 就 来 实现 这 一 功能 。 本 实例 通过 让..else.… 语 名 实现 对 登录 用 户 权限 的 控制 ， 运 
行 结 果 如 图 2.31 所 示 。 


在 后 面 的 很 多 实例 中 都 可 以 找到 它 的 身影 。 


趣味 指数 ; 容 相 页 容 


用 Ps 
二 码 :e000q| 


当前 是 YIF 用 户 


图 2.31 控制 登录 用 户 权限 


力 关键 技术 


大 多 时 候 ， 总 是 需要 在 满足 某 个 条 件 时 执行 一 条 语句 ， 不 满足 时 执行 另 一 条 语句 。 为 了 适应 这 样 的 需求 ， 
用 户 可 以 使 用 让 语句 的 else 子 句 ， 其 语法 如 下 : 


iflexpr) {statementl:}else{statement2:} 

如 果 表 达 式 expr 的 值 为 TRUE, 则 执行 statementl 语句 ; 如 果 表 达 式 expr 的 值 为 FALSE, 则 执行 statement2 
语句 。 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 确 定 ”按钮 时 ， 程 序 通过 POST 方法 接收 传递 过 来 的 数据 ， 并 且 通 过 
.else.…. 选 择 语句 设 定 条件 ， 当 符合 条 件 时 利用 echo 语句 输出 “当前 是 VIP 用 户 ”， 和 否则 输出 “您 只 是 一 个 游 
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客 ”， 其 代码 如 下 : 


hp 
这 $_ POST[sub]){ 
// 判 断 通过 POST 接收 的 参数 结果 是 否 符合 条 件 
这 $_ POST[muser] 一 mr and$ POST[pwd] 一 'mrsofr){ 
echo "当前 是 VIP 用 户 "; /符合 条 件 的 结果 

jslsef 

echo "您 只 是 一 个 游客 "; // 不 符合 条 件 的 结果 

J 
了 


?> 


(2) 将 该 文件 存储 于 \MR\02\060 文件 夹 中 ， 命 名 为 index php。 运 行 结果 如 图 2.31 所 示 。 


心 法 领悟 060: 使 用 站...else... 语 句 的 优点 。 
让 .else.…. 语 句 是 寺 语 句 的 另 一 种 形式 ， 结 构 上 相对 站 语 句 要 清晰 。 


ee SS 8 | 
实例 061 趣味 指数 : 依依 傅 良 | 
图 实例 说 明 


类 似 于 留言 板 等 一 些 功能 较 单一 的 网 站 ， 可 以 通过 switch 语句 制作 网 页 框架 将 所 有 内 容 包含 到 主页 中 。 本 
实例 通过 switch 语句 、include 语句 来 演示 网 页 框架 的 制作 ， 运 行 结果 如 图 2.32 所 示 。 


点 击 包含 
inc.php 文件 


Es 

;i 
x 硬是 荐 二 (各 
AN 有 < 


图 2.32 网 页 框架 的 制作 


图 关键 技术 


switch 语句 和 break 语句 的 灵活 运用 是 本 实例 的 关键 。 
(1) switch 语句 和 具有 同样 表达 式 的 一 系列 的 站 语 句 相似 。 很 多 场合 下 需要 把 同一 个 变量 (或 表达 式 ) 与 
很 多 不 同 的 值 比 较 ， 并 根据 它 等 于 哪个 值 来 执行 不 同 的 代码 ， 其 语句 格式 如 下 : 


switch(variable) { 

case valuel: 
statement]:; 
break: 

case value2: 
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default: 
default statement n: 
} 


switch 语句 根据 variable 的 值 ， 依 次 与 case 中 的 value 值 相 比 较 ， 如 果 不 相等 ， 继 续 查 找 下 一 个 case; 如 果 
相等 , 就 执行 对 应 的 语句 , 直到 switch 语句 结束 或 遇 到 break 为 止 ,一般 switch 语句 最 终 都 有 一 个 默认 值 default， 
如 果 在 前 面 的 case 中 没有 找到 相符 的 条 件 ， 则 输出 默认 语句 〔 与 else 语句 类 似 ) 。 

(2) break 语句 用 于 结束 当前 for、foreach、while、do...while 或 者 switch 结构 的 执行 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 ， 利 用 switch 语句 获取 从 地 址 栏 传递 的 数据 ， 并 且 将 数据 与 switch 语句 中 
的 case 做 比较 ， 当 地 址 栏 传递 的 数据 与 case 中 的 数据 相等 时 ， 包 含 指定 文件 ， 并 且 利用 break 语句 跳出 switch 


语句 ， 其 代码 如 下 : 
<?php 
switch($_GET['link ]){ // 通 过 地 址 栏 接收 参数 
case "主页 ": // 如 果 值 为 主页 
include('ine.php); // 包 含 inephp 文件 
break; /| 结束 执行 switch 语句 
case "注册 ": // 如 果 值 为 注册 
include('ine_1.php); 
break; 
case "浏览 ": // 如 果 值 为 浏览 
include('ine_2.php); 
break; 
default: // 默 认 情况 下 ， 包 含 ine.php 文件 
include('ine.php); 
> } 
(2) 将 该 文件 存储 于 \MR\02\061 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.32 所 示 。 
图 秘笈 心 法 


心 法 领悟 061: switch 语句 的 实现 原理 。 
switch 语句 在 执行 时 ， 即 使 遇 到 符合 要 求 的 case 语句 段 ， 也 会 继续 往 下 执行 ， 直 到 switch 结束 。 为 了 避免 
这 种 浪费 时 间 和 资源 的 行为 ， 一 定 要 在 每 个 case 语句 段 后 添加 break 跳 转 语句 跳出 当前 循环 。 


实 高 级 


力 实例 说 明 


验证 码 的 作用 是 防止 用 户 亚 意 注册 而 降低 数据 库 和 网 站 本 身 的 性 能 。 本 实例 应 用 switch 语句 通过 PHP 图 像 
函数 来 演示 图 片 验 证 码 的 制作 ， 运 行 结果 如 图 2.33 所 示 。 


2.33 图 片 验证 码 
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图 关键 技术 


本 实例 的 关键 点 是 验证 码 函 数 和 switch 语句 的 联合 应 用 ， 其 应 用 到 的 函数 如 下 : 
(1) header0 函 数 
当 参 数 为 Content-type:image/png 时 使 用 header0 函 数 表示 将 图 片 输出 到 浏览 器 。 
void header ( string string [, bool replace [. int http_response_codc]]): 
(2) imagecreatetruecolor() 函 数 
新 建 一 个 真 彩色 图 像 ，imagecreatetruecolor0 函 数 返回 一 个 图 像 标识 符 , 代表 了 一 幅 大 小 为 x_size 和 y_size 
的 黑色 图 像 。 


Tesource imagecreatetruecolor ( int x_size, int y_size); 

(3) imagecolorallocate0) 函 数 

为 一 幅 图 像 分 配 颜 色 ，imagecolorallocate0) 函 数 返回 一 个 标识 符 ， 代 表 了 由 给 定 的 RGB 成 分 组 成 的 颜色 。 
image 参数 是 imagecreate() 函数 的 返回 值 ; red、green 和 blue 分 别 是 所 需要 的 颜色 的 红 、 绿 、 蓝 成 分 。 这 些 参 
数 是 0~255 的 整数 或 者 十 六 进 制 的 0x00~-0xFF imagecolorallocateO) 函 数 必须 被 调用 以 创建 每 一 种 用 在 image 所 
代表 的 图 像 中 的 颜色 。 


int innagecolorallocate (resouree inage, int ied, int green, int bie); 

(4) imagettftext0 函 数 

用 TrueType 字体 向 图 像 写 入 文本 ，imagettftext0 函 数 是 将 字符 串 text 添加 到 image 所 代表 的 图 像 上 ， 从 坐 
标 (x,y)( 左 上 角 为 (0, 0)) 开始 ， 角 度 为 angle， 颜 色 为 color， 使 用 fontfile 所 指定 的 TrueType 字体 文件 。 根 
据 PHP 所 使 用 的 GD 库 的 不 同 ， 如 果 fontfile 没有 以 "开头 ， 则 'ttf 将 被 加 到 文件 名 之 后 并 且 会 搜索 库 定 
义 字体 路 径 。 

array imagettfiext (Tesouree image, int size, int angle, int x, int y, int color, string fontfile, singtexgj; 

(5) imagegif0 函 数 

以 GIF 格式 将 图 像 输 出 到 浏览 器 或 文件 ，imagegif0 函 数 从 image 图 像 以 filename 为 文件 名 创建 一 个 
GIF 图 像 。image 参数 是 imagecreate() 函数 的 返回 值 。 

inna (resouree inage [ ting SEE 

(6) int imagestringO 函 数 

水 平地 画 一 行 字符 串 ，int imagestringO 函 数 用 col 颜色 将 字符 串 s 画 到 image 所 代表 的 图 像 的 (x,y) 坐 标 处 
(图 像 的 左上 角 为 (0, 0)) 。 如 果 font 是 1、2、3、4 或 5， 则 使 用 内 置 字体 。 

nt magestring ( resouree inage, int font, int x, nt y, stiing s, int eol); 
图 设计 过 程 

(1) 创建 index.php 文件 , 通过 GET 方式 接收 由 地 址 栏 传 递 的 数据 并 且 将 参数 与 case 的 值 进行 比较 ， 当 两 
者 相等 时 引入 指定 图 片 ， 通 过 switch 语句 进行 操作 ， 其 代码 如 下 : 


php 


switch($_GET[link]){ // 取 得 通过 地 址 栏 传递 的 参数 
cmse "文字 ": // 当 参数 等 于 文字 时 
?> 
<img sre="yzm_1.php"> // 引 入 图 片 
<?php 
break: /| 结束 执行 switch 语句 
case "数字 ": // 当 参数 等 于 数字 时 
?> 
<img sre="yzm 2.php"> // 引 入 图 片 
<?php 
break; /| 结束 执行 switch 语句 
default: // 上 默认 情况 下 
Se 
<img ste="yzm 2.php"> 
<?php 
} 
?> 
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(2) 创建 yzm_1.php 文件 ， 应 用 图 像 处 理 函 数 生成 文字 验证 码 ， 其 代码 如 下 : 
<?php 


header ( "Content-type: text/html; charset=UTF-8" ); 
header("Content-type:image /gif"): 

Simage = imagecreatetruecolor(80.30): 

S$font = Font FZHCJW.TTF'; 

Sbg = imagecolorallocate($image,255,255,255); 
Scolor = imagecolorallocate($image.255.,0,255); 
imagettfiext($image,20,0,8.20,$color,$font."mrsoft"); 
imagegif($image); 

?> 


/设置 文件 编码 格式 
/设置 页 面 类 型 

// 创 建 画布 

/定义 字体 

/定义 背景 颜色 


/输出 文字 
/生成 图 像 


(3) 创建 yzm_2.php 文件 ， 应 用 图 像 处 理 函 数 生成 数字 验证 码 ， 其 代码 如 下 : 


<?php 
header("Content-type:image/gif"); 
Simage = imagecreatetruecolor(40.20); 
Sbg = imagecolorallocate($image,225,225,0); 
$color = imagecolorallocate($image.255.,0,255); 
for($b = 0;$b <4; Sb ++){ 
$a =rand(1,9); 

imagestring($image,3,8,5,$a,$color); 

> 


国 秘笈 心 法 


心 法 领悟 062: 开启 GD2 支持 。 

PHP 5.0 中 GD2 函数 库 已 经 作为 扩展 被 默认 安装 ,但 目前 有 些 版 本 中 ， 还 需要 对 php.ini 文件 进行 设置 来 激 
活 GD2 函数 库 。 用 文本 编辑 工具 ， 如 记事 本 等 程序 打开 php.ini 文件 ， 将 文件 中 的 “;extension=php_gd2.dll” 选 
项 中 的 分 号 “;” 删 除 ， 保 存 修改 后 的 文件 ， 并 重新 启动 Apache 服务 器 即 可 激活 GD2 函数 库 。 


实例 063 


力 实例 说 明 


// 设 置 页 面 格式 
/生成 画布 

/定义 背景 颜色 
/定义 图 像 颜色 

// 生 成 随机 验证 码 


/输出 验证 码 
/生成 图 像 


高 级 
趣味 指数 : 究 室 家 请 


一 些 手机 在 开机 时 会 出 现 开机 问候 语 或 者 今日 日 程 提示 。 本 实例 就 是 设计 类 似 这 样 的 程序 ， 通 过 switch 语 
句 根据 当前 日 期 ， 给 出 健康 生活 提示 信息 ， 运 行 结果 如 图 2.34 所 示 。 


力 关键 技术 


2.34 ”健康 生活 提醒 


本 实例 的 关键 点 是 利用 switch 语句 ,将 地 址 栏 传递 的 数据 与 switch 语句 中 的 case 值 进行 比较 ， 符 合 条 件 的 


利用 echo 语句 输出 对 应 数据 。 
力 设计 过 程 


(1) 创建 PHP 脚本 文件 。 首 先 通过 dateO) 函 数 取 得 当前 是 星期 几 ， 然 后 利用 switch 语句 进行 操作 ， 并 通过 


echo 语句 输出 信息 提示 ， 其 代码 如 下 : 
<php 
$a = date("1"): 


// 取 得 当前 是 星期 几 
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switch(Sa){ 
case "Monday": // 当 前 如 果 是 星期 一 
echo "今天 是 星期 一 ， 一 周 忙碌 生活 开始 了 ": /输出 
break; 
case "Tuesday": // 当 前 如 果 是 星期 二 
echo "今天 是 星期 二 ， 电 视 台 下 午 两 点 以 后 部 分 休息 " /输出 
break; 
case "Wednesday": // 当 前 如 果 是 星期 三 
echo "今天 是 星期 三 ， 下 午 有 乒乓 球 比赛 "; /输出 
break; 
case "Thursday": // 当 前 如 果 是 星期 四 
echo "今天 是 星期 四 ， 晚 上 有 NBA 的 重播 "; /输出 
break: 
case "Friday": /1/ 当 前 如 果 是 星期 五 
echo "今天 是 黑色 星期 五 。。。。。。 // 输 出 
break; 
case "Saturday": // 当 前 如 果 是 星期 六 
echo "今天 是 星期 六 ， 明 天 就 放假 了 哈哈 哈 ": // 输 出 
break; 
case "Sunday": /1/ 当 前 如 果 是 星期 日 
echo "今天 是 星期 天 ， 可 以 玩 上 一 整 天 ": /| 输出 
} 
?> 
(2) 将 该 文件 存储 于 \MR\02\063 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.34 所 示 。 
力 秘笈 心 法 


心 法 领悟 063: 比较 switch 语句 与 这..else.… 语 句 。 
switch 语句 与 if.…else.…. 语 句 在 功能 上 基本 相同 ， 但 是 switch 语句 更 加 灵活 ， 格 式 更 加 鲜明 ， 结 构 更 加 
清晰 。 


2.5 循环 语句 


在 实际 应 用 中 ， 经 常会 遇 到 一 些 操作 并 不 复杂 ， 但 需要 反复 处 理 的 问题 ， 为 此 ，PHP 提供 了 循环 语句 来 实 
现 循环 结构 的 程序 设计 。 循 环 语句 是 指 能 够 按照 一 定 的 条 件 重复 执行 某 段 功 能 代码 的 代码 结构 。 循 环 语句 分 为 
以 下 4 种 : 
while 循环 语句 。 
do..….while 循环 语句 。 
for 循环 语句 。 
foreach 循环 语句 。 


实 | 
看 实例 说 明 


while 循环 结构 的 作用 是 重复 执行 一 段 代 码 或 完成 相同 的 动作 。 本 实例 通过 while 语句 循环 输出 数组 中 存储 
的 员工 生日 信息 ， 运 行 结 果 如 图 2.35 所 示 。 


回回 回回 
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86 年 6 月 ?日 是 张 ? 的 生日 


图 2.35 员工 生日 列表 


图 关键 技术 


while 循环 是 PHP 中 最 简单 的 循环 语句 。while 循环 语句 根据 某 一 条 件 进 行 判 断 ， 决 定 是 否 执行 循环 ， 其 语 
法 格式 是 : 

while (expn){ 

statement 

} 

当 表 达 式 expr 的 值 为 TRUE 时 ， 将 执行 statement 语句 ， 执 行 结束 后 ， 再 返回 到 expr 表达 式 继续 进行 判断 。 
直到 表达 式 的 值 为 FALSE 才 跳 出 循环 ， 执 行 大 括号 后 面 的 语句 。 


图 设计 过 程 
创建 index.php 文件 。 首 先 ， 利 用 数组 函数 将 数据 信息 存储 在 数组 变量 中 。 然 后 ， 定 义 循环 变量 的 初始 值 为 


0， 最 大 值 不 超过 数组 长 度 ， 并 在 循环 内 部 做 自 增 运算 。 最 后 ， 利 用 while 循环 输出 结果 ， 其 代码 如 下 : 
<?php 
$a=array("86 年 6 月 1 日 是 张 1 的 生日 ""86 年 6 月 2 日 是 张 2 的 生日 ""86 年 6 月 3 日 是 张 3 的 生日 ""86 年 6 月 4 日 是 张 4 的 生日 ""86 
年 6 月 4 日 是 张 4 的 生日 ""86 年 6 月 5 日 是 张 5 的 生日 ""86 年 6 月 6 日 是 张 6 的 生日 ""86 年 6 月 7 日 是 张 ?的 生日 ""86 年 6 月 7 日 是 张 ?7 


的 生日 "); // 定 义 数组 
$b=0; // 给 变量 赋 初 始 值 
while($b < count($a){ // 根 据 数组 长 度 循环 输出 
echo $a[$b]."<br><br>"; /输出 数组 元 素 
Sb++: 
} 
> 
国 秘笈 心 法 


心 法 领悟 064: 介绍 while 语句 的 变 体 。 
while 循环 语句 还 有 另 一 种 表示 形式 ， 即 do...while， 详 细 说 明 请 参见 实例 065。 


| 


: 


实例 065 趣味 指数 : 窒 广 食 三 


力 实例 说 明 
本 实例 通过 do while 循环 语句 循环 读 取 数据 库 中 的 数据 ,输出 员工 的 详细 信息 ， 运 行 结果 如 图 2.36 所 示 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


所 在 地 址 :Qs 


期 ，1986-06-06 所 1 


姓名 ， 部 请 年龄， ee 0000-00-00 人 
幅 名, 黄 葵 年 训 册 ， 


图 2.36 员工 详细 信和 浏览 


图 关键 技术 


while 语句 还 有 另外 一 种 表示 形式 ， 即 do...while。do...while 循环 语句 和 while 循环 语句 非常 类 似 ， 只 是 
do.…while 循环 语句 在 循环 底部 检测 循环 表达 式 ， 而 不 是 在 循环 的 顶部 进行 检测 。do.…while 循环 语句 的 语法 格 
式 如 下 : 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 mysql_connect0 函 数 连 接 MySQL 数据 库 ， 并 通过 mysql_query0 函 
数 定义 页 面 的 编码 格式 。 然 后 ， 定 义 SQL 查询 语句 并 返回 结果 集 。 最 后 ， 通 过 do.…while 语句 循环 输出 数据 库 
中 的 数据 ， 其 代码 如 下 : 
<?php 


$conn = mysql_connect("localhost", "root","111") // 连 接 数 据 库 服务 器 
mysql_select_db("db_database02", $conn); // 连 接 数据 库 
mysql_query("SET NAMES GBK"): // 设 置 编码 格式 
Srs = mysql_query("select * from tb_while"); // 执 行 查询 

dof 


echo "姓名 : "iconv(gbk'vutf-8'\Srst[1])."&nbsp:&nbsp: 年 龄 : "iconv(gbk' utf-8',Srst[2])."&nbsp:&nbsp: 出 生日 期 ; 
"iconv('gbk','utf-8',$rst[3])."&nbsp;&nbsp; 所 在 地 址 : ".iconv('gbk','utf-8',$rst[4])."&nbsp;&nbsp:QQ: ".iconv('gbk','utf-8',$rst[5])."<br><br>"; 
}while($rst = mysql_fetch_array($rs)): 
> 


(2) 将 该 文件 存储 于 \MR\02\065 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.36 所 示 。 
图 秘笈 心 法 
心 法 领悟 065， 使 用 do...while 语句 的 注意 事项 。 


在 使 用 do…while 语句 之 前 ， 要 考虑 程序 是 否 有 必要 在 判断 条 件 之 前 运行 一 次 ， 如 果 没有 必要 ， 尽 量 不 要 
使 用 该 语句 ， 否 则 可 能 会 出 现 意外 的 输出 结果 。 


实例 066 趣味 指教 : 容 全 全 全 


国 实例 说 明 


在 操作 数据 库 的 过 程 中 可 能 会 出 现 很 多 无 用 的 元 余 信息 ， 可 以 使 用 
while 循环 语句 将 其 循环 删除 。 本 实例 通过 while 循环 语句 实现 员工 信息 的 批 
量 删 除 ， 运 行 结果 如 图 2.37 所 示 。 


删除 3 | 条 记录 国际 ] ) 


图 2.37 员工 信息 的 批量 删除 
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图 关键 技术 


本 实例 的 关键 点 是 while 循环 语句 的 灵活 运用 。 根 据 提交 的 参数 值 ， 执 行 while 循环 语句 ， 在 循环 体 中 执行 
删除 操作 ， 完 成 数据 的 循环 删除 操作 。 


国 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 连 接 MySQL 数据 库 服务 器 ， 选 择 MySQL 中 名 称 为 db_while 的 数据 库 ， 


并 设置 页 面 的 编码 格式 。 然 后 ， 定 义 循环 变量 ga 和 $b， 将 第 一 层 while 循环 中 的 循环 条 件 设置 为 Sb<$a， 然 后 ， 
再 次 利用 while 语句 循环 输出 数据 表 中 的 数据 ， 并 执行 数据 的 删除 操作 ， 其 代码 如 下 : 


<2php 
if($_POST[sub) { /通过 POST 方式 获取 参数 
S$conn = mysql_connect("localhost", "root","111"); // 连 接 MySQL 数据 库 
mysql_select_db("db_while", Sconn); // 连 接 数据 库 
mysql_query("SET NAMES GBK"); // 定 义 编码 格式 
$a=$_POST[te]: // 接 收文 本 框 参数 
$b=0; // 定 义 变量 
while($b < $a){ //while 循环 
Srs = mysql_query("select + from tb_while"); // 执 行 查询 操作 
while($rst = mysql_fetch_array(Srs)){ // 将 查询 结果 保存 在 数组 中 
$sql = "delete + from tb_while where id = $b"; /SQL 语句 
mysql_query($sq)); // 执 行 删 除 操作 
echo "姓名 为 ".Srstfname]." 的 员工 已 被 删除 <br>"; /输出 被 删除 的 员工 姓名 
Sbt+t; 
1 
} 
} 
> 
(2) 将 该 文件 存储 于 \MR\02\066 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.37 所 示 。 
>» 
图 秘笈 心 法 


心 法 领悟 066: 使 用 while 语句 嵌 套 的 注意 事项 。 
while 循环 语句 允许 语句 嵌 套 ， 但 在 嵌 套 的 过 程 中 要 注意 保持 层次 结构 的 清晰 。 


| 高 级 | 
全 | 
二 | “六 ei tieded 
实例 加 四 回国 四 国 加 加 | 
图 实例 说 明 
很 多 时 候 PHP 编码 需要 和 HTML 编码 混 编 , 例如 , 输出 表格 打印 HTML 标签 

等 。 本 实例 应 用 两 层 for 语句 循环 制作 动态 表格 ， 运 行 结 果 如 图 2.38 所 示 。 


图 关键 技术 2.38 表格 的 动态 创建 


for 循环 语句 能 够 按照 已 知 的 循环 次 数 进行 循环 操作 ， 主 要 应 用 于 多 条 件 情况 下 的 循环 操作 ， 不 适合 在 单一 
条 件 下 使 用 。 这 一 点 从 该 语句 的 语法 中 就 可 以 看 出 ， 其 条 件 的 表达 式 有 3 个 ， 语 法 格式 如 下 : 

for (sxprl; expr2: expr3){ 

statement; 

} 

其 中 ,exprl 为 变量 初始 赋值 ;expr2 为 循环 条 件 , 即 在 每 次 循环 开始 前 求 值 ,如果 其 值 为 真 , 则 执行 statement， 
否则 ， 跳 出 循环 ， 继 续 往 下 执行 ，expr3 为 变量 递增 或 递减 ， 即 每 次 循环 后 被 执行 。 


PHP 开发 实例 大 全 《基础 卷 ) 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 for 循环 中 的 循环 变量 Sa。 设 定 Sa 的 初始 值 为 0， 最 大 值 为 4， 并 且 


每 执行 一 次 循环 就 做 一 次 自 增 运算 。 然 后 ， 利 用 循环 嵌 套 的 知识 定义 内 层 循环 ， 内 层 循环 的 循环 变量 Sb 的 初始 
值 为 0， 最 大 值 为 7， 并 且 同 样 做 自 增 运算 。 最 后 ， 利 用 echo 语句 输出 信息 ， 其 代码 如 下 : 


<php 
for(Sa= 0:$a < 5;5at+){ 作 层 for 循环 
echo "<table border='1'bordercolor=#000099' bordercolorlight=#000099' cellspacing=0'>"; 
bo // 表 格 标签 
for($b = 0:Sb < 8:$b++){ /2 层 for 循 环 
echo "<td>"; /表格 标签 
echo $b: /输出 数据 
echo “</td>"; 
La ct 
echo "</table>"; 


} 
?> 
(2) 将 该 文件 存储 于 \MR\02\067 文件 夹 下 ， 命 名 为 ndex.php。 和 运行 结果 如 图 2.38 所 示 。 
图 秘笈 心 法 


心 法 领悟 067: for 循环 语句 。 
for 循环 语句 在 PHP 循环 结构 中 比较 常用 ， 结 构 也 比较 简单 ， 所 以 一 定 要 灵活 掌握 此 循环 语句 。 在 本 实例 
中 ， 虽 然 其 定义 变量 的 最 大 值 分 别 为 4 和 7， 但 是 由 于 在 for 循环 中 ， 其 条 件 表达 式 的 值 是 从 等 于 0 开始 ， 所 以 
循环 语句 分 别 执行 了 5 次 和 8 次 。 
高 级 : 


力 实例 说 明 


购物 车 是 电子 商务 系统 中 的 常见 模块 ，SESSION 作为 一 种 会 话机 制作 用 不 可 小 凯 。 本 实例 综合 运用 while 
语句 、switch 语句 、 让 语句 和 for 语句 实现 一 个 简单 的 SESSION 购物 车 功能 ， 运 行 结果 如 图 2.39 所 示 。 


会 牌 折 优 惠 ! 


图 2.39 SESSION 购物 车 中 数据 的 读 取 
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图 关键 技术 


(1) 通过 switch 语句 根据 地 址 栏 中 传递 的 参数 值 ， 实 现在 不 同 商品 页 面 之 间 的 跳 转 。 
(2) 通过 让 语句 对 form 表单 提交 的 值 进行 判断 ， 进 而 执行 不 同 的 操作 。 
(3) 通过 while 语句 和 for 语句 完成 购物 车 中 购买 商品 的 输出 。 


设计 过 程 
(1) 创建 index.php 文件 ， 通 过 switch 语句 根据 地 址 栏 中 传递 的 参数 值 ， 实 现在 不 同 商品 页 面 之 间 的 跳 转 ， 


其 代码 如 下 : 
php 
switch($_GET[link]){ 
case "电脑 ": 
include once("in 1.php"); 
break; 
case "家 庭 影院 ": 
include_once("in_2.php"); 


break; 

case "全 自动 洗衣 机 ": 
include_once("in_3.php"); 
break; 


case "数码 摄像 机 ": 
include_once("in_4.php"); 
break: 


case "山地 自行 车 ": 

include_once("in_5.php"); 

break; 

default: 

include_once("in_image.php"); 
是 


?> 
(2) 创建 config.php 文件 。 首 先 ， 编 辑 form 表单 ， 执 行 不 同 的 操作 。 然 后 ， 应 用 站 语句 根据 form 表单 提 
交 的 值 进行 判断 ， 进 而 执行 不 同 的 操作 。 最 后 ， 通 过 while 和 for 语句 循环 输出 购物 车 中 存储 的 商品 ， 其 关键 代 
码 如 下 : 


<form action="" method="post"> 
我 要 购买 <input type="text" size="2" value ="1" name="num"> 件 
<input type="submit" name="sub" value=" 放 入 购物 车 " style="background-image:url(pic/button_2.jpg);color:red"> 
<input type="submit" name="sub1" value=" 结 账 " style="background-image:url(pic/button_3.jpg);color:red"> 
<input type="submit" name="sub2" value=" 首 页 " style="background-image:url(pic/button_1.jpg):color:red"> 
</form> 
<2php 
if($_POST[sub2D){ 
echo "<script>location.href='index.php'</seript>"; 


} 
if($_POST[sub){ 
$str = explode("#",$_SESSION[id]): 
include("class/mysql.php"); 
$sql = "insert into tb_shop(id.name.number.money.moneyother.other)values(".$str[O].$str[1]','$str[2]''$str[3]"$str[4])": 
iftmysql_query($sql){ 
mysql_close($conn); 
echo "<script>alert(' 已 经 放 入 购物 车 )</script>": 
} 


} 

if($_POST[sub1] || $_GET['sub1D{ 
require_once("class/mysql.php"): 
$sq = "select * from tb_shop"; 
Srs =mysql query($sq): 


<form action ="config/table.php" method="post"> 
<input type="submit" name="sub3" value=" 删 除 " style="background-image-url(pic/button_3.jpg):color:red"> 
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</form> 
<?php 
while(Srst = mysql_fetch_row(Srs)) 
for($a = 0:$a < 6;$a++){ 


> 
<tr><td><?php echo Srst[$a]?></td></tr> 
<?php 
> 
</table> 
<a href="config/money.php"><img sre="pic/bu jpg"></a> 
<php 
} 
?> 
(3) 创建 table php 文件 ， 执 行 删除 指定 商品 的 操作 ， 其 关键 代码 如 下 : 
<php 
require_once("../class/mysql.php"); // 包 含 数据 库 连 接 文 件 
$sq = "select * from tb_shop"; /定义 SQL 查询 语句 
Srs= mysql_query(Ssq); /执行 查询 操作 
?> 
<table> 
?php 
while($rst = mysql_fetch_row($rs){ // 循 环 输出 商品 信息 
> 
<tr><td> 商 品 编码 : <?php echo $rst[0]:?></td><td> 商 品名 称 : <?php echo $rst[1]:;?></td></tr> 
<tr><td> 购 买 数量 :<?php echo Srst[2]:?><hr></td><td> 金 额 总 计 : <?php echo S$rst[3]:?><hr></td></tr> 
<!--tr><td> 商 品 运费 :<?php echo Srst[4];?><hr></td><td> 其 他 声明 ; <?php echo $rst[5]:?><hr></td></tr--> 
<php 
} 
> 
<itd> 
</tr></table></td></tr></table> 
<2php 
if($ POST[sub4D)f 
$sqlser = "delete from tb_shop where id ='$_POST[tt]": // 定 义 SQL 语句 
if(mysql_query($sqlser){ // 执 行 删除 操作 
echo "<script>alert( 商 品 删除 成 功 ")</script>"; 
echo "<script>window .location.href="table.php':</seript>"; 
} 


) 
if($_POST[subS){ 
echo "<script>window.location href="../index.php?link= 电 脑 &sub1=1";</script>"; 


} 
bo 

(4) 编辑 mysql.php 文件 ， 实 现 与 数据 库 的 连接 。 

航 心 法 
心 法 领悟 068: 知识 对 接 。 
购物 车 的 知识 相对 较 复杂 ， 在 本 书 第 5 章 的 实例 266 中 将 对 购物 车 进行 详细 讲解 。 

高 级 | 

9 趣味 指数 : 妇女 太太 


实例 069 


力 实例 说 明 


员工 信息 一 般 存 在 于 人 事 信息 平台 的 后 台 系统 中 ， 对 员工 信息 的 管理 本 身 可 以 作为 一 个 典型 的 模块 被 使 用 。 
本 实例 通过 for 循环 语句 实现 对 员工 数据 的 读 取 、 修 改 和 删除 操作 ， 运 行 结 果 如 图 2.40~ 图 2.42 所 示 。 
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图 2.40 员工 数据 的 读 取 


未 自 http://le 


at 


图 2.42 员工 数据 的 修改 


力 关键 技术 


本 实例 通过 for 循环 语句 读 取 查询 结果 集中 的 数据 ,完成 数据 的 循环 输出 ,并且 创建 删除 和 修改 超 链 接 ， 应 
用 站 语句 对 超 链接 传递 的 参数 值 进 行 判 断 ， 实 现 对 数据 的 删除 和 修改 操作 。 有 关 for 循环 语句 的 详细 说 明 请 参 
见 实例 067， 站 语句 的 详细 讲解 请 参见 实例 059。 


图 设计 过 程 
创建 index.php 文件 。 首 先 ， 连 接 MySQL 数据 库 执行 查询 操作 取得 查询 结果 集 。 然 后 ， 通 过 for 语句 循环 
输出 结果 集中 的 数据 。 最 后 ， 通 过 让 语句 对 超 链接 的 参数 值 进行 判断 ， 进 而 执行 删除 和 修改 操作 ， 其 关键 代码 


如 下 : 
<?php 
Slink = mysql_pconnect("localhost", "root", "111"); // 连 接 MySQL 
mysql_select_db("db_database02".$link): // 连 接 数 据 库 
mysql_query("SET NAMES GBK"): /设置 编码 格式 
Squery = "SELECT * FROM tb_for_1"; //SQL 语句 
Sresult = mysql_query($query): // 执 行 查询 操作 
for ($i= mysql_num rows($result) - 1: Si>= 0; $i--) { //for 循环 
if(lmysql_data_seek($result. Si) { // 如 果 指 针 不 向 下 移动 
echo "Cannot seek to row $i: " . mysql_error0 . "\n"; 
continue; 
} 
if(!(S$row = mysql_fetch_object($result))) // 如 果 结果 集 不 存在 
continue: 
echo "<tr><td>$row->name</td><td>$row->age</td><td>$row->sex</td><td>$row->tel</td><td>$row->address</td> 
<td><a href='1.php?id=$row->id&delete=1><b> 删 除 </b></a>&nbsp:&nbsp:<a hre 人 ="1.php?id=$row->id&update=1'><b> 修 改 
<lb></a></td></tr>"; 
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4 
mysql_free_result($result); /释放 结果 集 
if($_GET[delete] — D{ // 如 果 地 址 栏 参数 delete 等 于 1 
$sql = "delete fromtb for 1 where id='$ GET[id]"; JWSQL 语句 
if(mysql_query($sqD)){ /执行 删除 操作 
echo "<script>alert( 删 除 成 功 );location href="1.php'</script>": /| 提示 框 信息 
区 
} 
if($_GET[update] 一 D{ // 如 果 地 址 栏 参数 update 等 于 1 
$sql = "select * from tb_for_1 where id =$_GET[id]"; //SQL 语句 
Srs =mysql_query($sql); /| 执行 查询 语句 
Srst =mysql fetch_array($rs); /取得 结果 集 
> 
</table><br><br> 
<form action="" method="post"> // 表 单 
// 使 文本 框 初始 值 为 数据 库 中 结果 
<input name="name" type="text" value="<?php echo $rst[name]:?>" size="6"> 
<input name="age" type="text" value="<?php echo Srst[agel]:?>" size="6"> 
<input name="sex" type="text" value="<?php echo S$rst[sex]:?>" size="6"> 
<input name="tel" type="text" value="<?php echo S$rst[tel]:?>" size="11"> 
<input name="address" type="text" value="<?php echo $rst[address]:?>" size="6"> 
<input type="submit" name="sub1" value=" 修 改 "> 
</form></td></tr></table></td></tr></table> 
php 


if($_POST[sub1D{ // 如 果 按 钮 被 单 击 
$sql = "update tb_for 1 set name ='$_ POST[name].age ='$_POST[age]',sex ='$_POST[sex]',tel ='$_POST[tel] ,address = 
'$_POST[address]' where id = 号 GET[id]"//sql 语句 


这 mysql_query($sqD){ /执行 更 新 操作 
echo "<script>alert(' 修 改 成 功 ):location.href="1 .php'</script>"; /提示 框 信息 
} 


} 


2> 


国 秘笈 心 法 


心 法 领悟 069: 使 用 地 址 栏 传递 参数 存在 风险 。 
通过 地 址 栏 传递 参数 是 存在 风险 的 ， 一 般 情况 下 应 使 用 POST 方式 传递 参数 。 如 果 一 定 要 使 用 GET 方式 传 
递 参数 ， 最 好 应 用 urlencode0 函 数 对 参数 进行 编码 。 


实例 070 


力 实例 说 明 


在 编程 世界 里 ， 算 法 是 一 门 独立 于 语法 、 函 数 之 外 的 知识 ， 它 着 重 考验 用 户 的 逻辑 思维 能 力 并 且 与 数学 知 
识 息 息 相 关 。 本 实例 通过 for 循环 语句 实现 网 页 版 九 九 乘法 表 ， 运 行 结果 如 图 2.43 所 示 。 


#1 =1 

2 * 1 =2|2 #2.=4 

3 #1=33*2=6 1 

1 = 机 28 =12|4 #4 =16 


5 * 1 =5l5 * 2kztols +:3 =15l5 + 4 =20l5 * 5 5325 广 2 + 
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图 2.43 ”网 页 版 九 九 乘法 表 
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国 关键 技术 
本 实例 的 关键 点 是 利用 for 循环 中 的 第 2 层 循环 控制 第 1 层 循环 ， 以 实现 指定 数据 的 输出 。 
力 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 定 义 第 1 层 循环 中 的 循环 变量 为 a， 设置 $a 的 初始 值 为 !， 最 大 值 为 9，， 并 且 每 


执行 一 次 循环 就 做 一 次 自 增 运算 。 然 后 ， 定 义 内 层 循环 中 的 循环 变量 为 Sb， 设 置 Sb 的 初始 值 为 1， 最 大 值 小 于 
$a， 并 且 做 自 增 运算 。 最 后 ， 将 第 2 层 循环 控制 的 数据 输出 到 页 面 ， 其 代码 如 下 : 


php 
for($a= 1:$a < 10:$a++){ // 第 1 层 循环 
echo "<tr>"; 
for($b= 1;$b <= $a;$b++){ // 第 2 层 循环 控制 第 1 层 循环 输出 
echo "<td>"; 
echo "$a * $b =".$a*$b; /1/ 输 出 结果 
echo"</td>"; 
J “</tr>"; 
> 
(2) 将 该 文件 存储 于 \MR\02\070 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.43 所 示 。 
国 秘笈 心 ; 
心 法 领悟 070: 形成 良好 的 算法 思维 。 
算法 不 是 一 朝 一 夕 就 可 以 掌握 的 ， 是 一 个 慢 慢 了 解 、 形 成 思想 的 过 程 。 


趣味 指数 : 仿 食 全食 
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实例 说 明 


用 户 在 进行 开发 时 ， 没 有 必要 将 小 型 的 数据 与 数据 库 进行 交互 ， 可 以 直接 将 其 存 入 数组 ， 这 样 不 仅 可 以 节 
约 开发 时 间 ， 还 可 节省 服务 器 资源 。 本 实例 通过 对 数组 函数 的 相关 操作 实现 读 取 数 组 购物 车 中 的 数据 ， 运 行 结 
果 如 图 2.44 所 示 。 


短 黄 : 30 元 《自理 》 
图 2.44 实现 读 取 
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图 关键 技术 


本 实例 的 关键 点 是 运用 foreach 语句 遍历 数组 ， 取 得 key 值 和 对 应 的 value 值 。foeach 循环 在 PHP 4.0 中 擅 
长 处 理 数 组 ， 是 遍历 数组 的 一 种 简单 方法 ; 在 PHP 5.0 中 ， 新 增加 了 对 对 象 的 支持 。 该 语句 的 语法 格式 如 下 ; 


foreach (array expression as $value) 
Statement 


或 
foreach (amray expression as $key => $value) 
statement 


foreach 语句 将 遍历 数组 array_expression, 每 次 循环 时 , 将 当前 数组 中 的 值 赋 给 $value (或 是 $key 和 $value) ， 
同时 ， 数 组 指针 向 后 移动 直到 遍历 结束 。 当 使 用 foreach 语句 时 ,数组 指针 将 自动 被 重 置 ， 所 以 不 需要 手动 设置 
指针 位 置 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 字符 串 变量 ， 并 且 在 变量 中 插入 “#” 作 为 字符 串 分 割 点 。 然 后 ， 利 
用 GET 方式 接收 地 址 栏 传递 的 参数 。 当 $_GET[push] 的 值 等 于 1 时 ， 输 出 JavaScript 成 功 提示 。 当 $_GET[pop] 


的 值 等 于 1 时 ， 利 用 字符 串 拆 分 函数 将 字符 串 变 量 以 “# ”分 割 ， 并 分 别 保存 到 数组 中 。 最 后 ， 利 用 foreach 语 
句 将 字符 串 数组 中 的 value 值 输出 到 页 面 中 ， 其 代码 如 下 : 


hp 
$str = "宝贝 ， 液 晶 电 脑 显示 器 # 一 口 价 ，900 元 # 运 费 ，30 元 (自理 ) "; // 定 义 字 符 串 
if($_GET[push] = 1){ // 通 过 GET 方式 取得 参数 
echo "<script>alert( 成 功放 入 购物 车 ");</script>"; // 提 示 消 息 
J) 
if($_GET[pop] =— D{ // 通 过 GET 方式 取得 参数 
S$strexplode = explode("#",$str): // 分 割 字 符 串 
foreach($strexplode as Skey => $value){ /遍历 数组 
> 
<tr><td><?php echo $value:?></td></tr> // 输 出 结果 
<?php 


} 
} 
x 


(2) 将 该 文件 存储 于 \MR\02\071 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.44 所 示 。 
力 秘笈 心 法 


心 法 领悟 071: 对 于 foreach 语句 的 说 明 。 
foreach 语句 仅 能 用 于 数组 ， 当 试图 将 其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。foreach 
语句 不 支持 用 “@ ”来 禁止 错误 信息 。 


力 实例 说 明 


用 户 注册 后 ， 系 统 为 了 保存 用 户 的 一 些 基本 信息 ， 包 括 用 户 名 、 密 码 等 相 
关 信 息 ， 以 及 跟踪 和 定位 不 同 用 户 从 而 更 好 地 服务 于 用 户 ， 同 时 为 了 提高 站 点 
的 安全 性 ， 避 免 由 于 网 速 慢 造成 用 户 注册 信息 的 重复 提交 ， 往 往 会 在 用 户 注册 
表 中 增加 验证 码 功 能 。 本 实例 通过 for 循环 实现 图 像 验证 码 的 生成 ， 运 行 结 果 ”图 2.45 图 像 验 证 码 的 生成 
如 图 2.45 所 示 。 


有 
高 级 | 
| 去 友 | 
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图 关键 技术 
本 实例 的 关键 点 是 for 循环 语句 和 rand0 函 数 的 灵活 运用 。 通 过 for 循环 输出 一 个 包含 4 个 图 像 的 验证 码 ， 
验证 码 的 取 值 由 随机 函数 rand0 生 成 。 


rand0 函 数 可 产生 一 个 随机 整数 ， 其 语法 如 下 : 

intrand ( [int min, int max] ) 

如 果 没 有 提供 可 选 参数 min 和 max，rand0 函 数 返回 0 到 RAND_MAX 之 间 的 伪 随 机 整数 。 例 如 ， 想 得 到 
2~8 (包括 2 和 8) 之 间 的 随机 数 ， 则 写 为 rand(2, 8)。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 数组 函数 定义 数组 并 分 别 将 图 片 的 地 址 信息 存 入 数组 中 。 然 后 ， 在 


for 循环 的 循环 体内 ， 利 用 随机 函数 取得 0~3 中 的 随机 数字 并 保存 在 变量 Srand 中 。 最 后 ， 利 用 拼接 字符 串 的 方 


法 输出 图 片 ， 其 代码 如 下 : 
<?php 


Sarray = array("pic/22.jpg","pic/3 jpg"."pic/4.jpg"."pic/S.jpg"): // 定 义 数组 
for($a= 0:$a < 4;$a++){ //for 循环 
Srand = rand(0,3); //0~3 的 随机 数字 
echo "<img sre = '$array[Srand]>"; // 输 出 图 像 


} 


?> 

(2) 将 该 文件 存储 于 \MR\02\072 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.45 所 示 。 
力 秘笈 心 法 

心 法 领悟 072: 图 像 验 证 码 的 刷新 。 

在 本 实例 中 ， 通 过 重新 链接 到 首页 来 实现 验证 码 的 刷新 操作 。 


2.6 跳 转 语 句 


跳 转 控制 语句 包括 break 和 continue 两 个 。 其 中 break 语句 可 以 终止 当前 的 循环 ， 而 continue 语句 只 能 终止 
本 次 循环 ， 并 进入 下 一 次 循环 中 。 


高 级 


实例 073 趣味 指教 : 容 食 食 三 


i 


图 实例 说 明 
break 语句 的 含义 是 结束 当前 for、foreach、while、do...while 或 者 switch 结构 的 执行 。 本 实例 通过 break 
语句 实现 控制 页 面 中 表情 图 的 输出 ， 运 行 结果 如 图 2.46 所 示 。 
6 查获 0 嘲笑)o EJ 
已 
图 2.46 控制 页 面 中 表情 图 的 输出 


力 关键 技术 
使 用 break 关键 字 可 以 终止 当前 的 循环 , 包括 while、do...while、for、foreach 和 switch 在 内 的 所 有 控制 语句 ， 
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其 在 for 语句 中 的 应 用 示例 如 下 : 
for($i=1;$1<=4;$i++){ // 应 用 for 循环 控制 语句 输出 表情 头像 
if($i==4){ // 判 断 变量 是 否 等 于 4 
[ee // 如 果 等 于 4， 使 用 break 语句 跳 转 循环 


} 
本 实例 将 break 语句 与 switch 语句 联合 使 用 ， 控 制 页 面 中 表情 图 的 输出 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “确定 ”按钮 时 ， 利 用 switch 语句 选择 输出 的 图 片 并 通过 break 语句 跳出 
当前 switch 语句 ， 其 代码 如 下 : 
<opl 


hp 
i($_GET[sub){ // 通 过 GET 方式 接收 参数 

switch($_GET['check D){ /lswitch 语句 
case "1": // 如 果 值 为 1 
echo "<img sre='image/1 .gif >"; /输出 图 像 1 
break; // 跳 出 语句 
case "2": // 如 果 值 为 2 
echo "<img src='image/2.gif>"; /输出 图 像 2 
break // 跳 出 语句 
Cae": // 如 果 值 是 3 
echo "<img sre='image/3.gif>"; /输出 图 像 3 
break: // 跳 出 语句 
case "4": // 如 果 值 为 4 
echo "<img sre='image/4.gif >"; /输出 图 像 4 
break; // 跳 出 循环 

} 

} 
> 
(2) 将 该 文件 存储 于 \MR\02\073 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.46 所 示 。 
> 0 
力 秘笈 心 法 


心 法 领悟 073: break 语句 的 妙用 。 
break 语句 可 以 接受 一 个 可 选 的 数字 参数 来 决定 跳出 几 重 循环 。 


宗 高 级 | 
实例 074 趣味 指数 : 请 禄 庚 庚 | 
实例 说 明 


break 语句 可 以 指定 跳出 循环 的 层 数 ， 一 般 被 用 在 控制 条 件 方面 。 本 实例 通过 break 语句 实现 控制 页 面 中 数 
据 的 输出 数量 ， 运 行 结果 如 图 2.47 所 示 。 


加 六 SD 本 DD 
EEEXZZN) 
图 2.47 控制 页 面 中 数据 的 输出 数量 
力 关键 技术 
本 实例 运用 break 语句 跳出 指定 的 几 重 循环 ， 其 语法 格式 如 下 : 
break n: 
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图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 多 重 for 循环 霸 套 输出 全 部 图 片 。 然 后 ， 在 多 重 嵌 套 中 定义 并 条 件 语 
句 ， 当 变量 Srand 中 的 随机 数值 为 2 时， 跳出 3 重 循环 ， 否 则 正常 输出 图 片 ， 其 代码 如 下 : 


hp 
for($a = 0:$a < 2:Sat+jf 咱 层 循环 
for($b = 0:$b < 2:$b++){ /人 2 层 循环 
for($c= 0:Sc< 4:$c+Hf //3 层 循环 
Srand = rand(1.4): /11~4 随机 数字 
echo "<img src=image/Srand_gif>": /输出 图 像 


} 
} 


} 
echo "<hr style='color:blue;>"; 


for($a= 0;$a <2;$at+){ 省 层 循环 
for($b = 0:$b < 2:$b++){ /全 层 循环 
for($c=0;$c < 4:$c++){ //3 层 循环 
Srand = rand(1,4); /~4 随机 数字 
if($rand (=2){ /条 件 语句 
echo "<img src=image/Srand gif>"; /| 输出 图 像 
jelsef 
break 3; /| 结束 3 个 层级 的 循环 


} 
} 
?> : 
(2) 将 该 文件 存储 于 \MR\02\074 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.47 所 示 。 
力 秘笈 心 法 
心 法 领悟 074: 灵活 运用 跳 转 语句 。 
跳 转 语句 一 定 要 灵活 运用 。 常 用 的 跳 转 语句 包括 break 语句 和 continue 语句 ，continue 语句 将 在 后 面 的 实例 
中 做 详细 介绍 。 


i 高 级 
实例 075 趣味 指数 : lolol 
力 实例 说 明 


在 循环 结构 中 ， 有 些 数据 是 不 需要 的 ， 想 要 跳 过 这 些 代 码 向 下 执行 就 需要 用 到 continue 语句 。 本 实例 通过 
continue 语句 实现 动态 改变 页 面 中 单元 格 的 背景 颜色 ， 运 行 结 果 如 图 2.48 所 示 。 


动态 交 公 
图 2.48 动态 改变 页 面 中 单元 格 的 背景 颜色 


图 关键 技术 


在 程序 执行 break 后 ， 程 序 将 跳出 循环 执行 流程 开始 继续 执行 循环 体 的 后 续 语句 。continue 跳 转 语句 的 作用 
没有 break 那么 强大 ，continue 只 能 终止 本 次 循环 而 进入 下 一 次 循环 中 。 在 执行 continue 语句 后 ， 程 序 将 结束 本 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
次 循环 的 执行 ， 并 开始 下 一 轮 循环 的 执行 操作 。continue 跳 转 语句 的 流程 控制 如 图 2.49 所 示 。 


continue 


图 2.49 continue 流程 控制 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 for 循环 定义 循环 变量 的 初始 值 为 0， 最 大 值 为 9， 并 且 每 执行 完 一 
次 循环 ， 循 环 变量 做 一 次 自 增 运算 。 然 后 ， 利 用 让 语句 定义 条 件 ， 当 循环 变量 小 于 等 于 5 时 ， 通 过 dechex() 函 


数 获 取 6 个 十 六 进 制 随机 数 ， 和 否则 终止 本 次 循环 。 最 后 ， 将 取得 的 6 个 十 六 进 制 数 添加 到 <table> 标 签 的 bgcolor 
属性 中 ， 实 现 动态 变色 ， 其 代码 如 下 : 


<2php 


for($b = 0:Sb < 10:$b++){ // 循 环 语句 
isSb <= 5){ /| 条 件 语句 
Srand.= dechex(rand(0,15)); /取得 6 个 十 六 进 制 数 
jelsef 
continue; // 不 满足 条 件 ， 重 新 执行 循环 
} 
} 
> 


<table height="55" bgcolor="#<?php echo Srand:?>">// 设 置 背 景 颜色 
<tr><td width="156"></td> 
</tr></table> 


(2) 将 该 文件 存储 于 \MR\02\075 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.48 所 示 。 
国 秘笈 心 法 
心 法 领悟 075: continue 语句 的 妙用 。 
continue 语句 也 可 以 指定 跳 转 层 级 数 。 
高 级 


趣味 指数 : 依依 依 良 


实例 076 | 


力 实例 说 明 
数学 中 有 这 样 一 道 题 ， 取 得 0~10 中 所 有 偶数 或 者 奇数 的 和 。 如 果 想 把 这 道 题 用 PHP 代码 表示 出 来 ， 则 需 
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要 使 用 跳 转 语句 continue 来 完成 。 本 实例 通过 跳 转 语句 continue 实现 屏蔽 偶数 次 的 数据 输出 , 运行 结果 如 图 2.50 
所 示 。 


a hs nh 
B#1=3/3 * 9 3 #7 =21|3 #27 
#1 =5[5 3E15 Et 7 =35|5 "9/245 
Wr 1 =7[7*"3 D1| [FF =49[r * 363 
9 *1 =9|9 * S20 #5 zd5[9 *# 7 =63|9 *# 9581| 


1 #7=7 | #9=9 


图 2.50 ”屏蔽 偶数 次 的 数据 输出 


力 关键 技术 
本 实例 的 关键 点 是 continue 语句 的 灵活 运用 ， 详 细 说 明 请 参见 实例 075。 
图 设计 过 程 
创建 PHP 脚本 文件 。 首 先 通过 for 循环 语句 动态 输出 HTML 的 <tr> 标 签 和 数据 ， 并 且 当 循环 变量 为 偶数 时 


终止 本 次 循环 。 然 后 ， 利 用 相同 的 方法 动态 输出 HTML 的 <td> 标 签 和 数据 。 最 后 ， 在 页 面 中 输出 如 图 2.50 所 示 
的 表格 ， 其 代码 如 下 : 


for($a= 1:$a < 10:$at+){ 作 层 循环 
if($a % 2— 0){ // 如 果 为 偶数 则 回 到 本 循环 开始 位 置 
continue; 
"<tr>"; 
for($b = 1:$b < 10:$b++){ /2 层 循环 
if$b %2!=0){ // 如 果 为 偶数 
echo "<td>"; 
echo "$a * $b =".$a+$b; /| 输出 结果 
echo "</td>"; 
jelsef 
continue; // 回 到 本 循环 的 开始 位 置 
} 
} 
nfte>" 
} 
> 
力 秘笈 心 法 


心 法 领悟 076: 求 余 运 算 符 。 
利用 “%” 运 算 符 可 取得 两 个 数 的 余数 ， 本 实例 通过 该 运算 符 判 断 是 否 为 偶数 ， 如 果 想 要 判断 是 否 为 奇数 ， 
只 需 将 条 件 设 定 为 不 等 于 1 即 可 。 


力 实例 说 明 
本 实例 通过 continue 语句 实现 跳 过 数据 输出 中 指定 的 记录 ， 运 行 结果 如 图 2.51 所 示 。 
力 关键 技术 


本 实例 应 用 continue 语句 跳 过 指定 的 循环 ， 输 出 指定 循环 以 外 的 数据 。 
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0、PHP 典 型 模块 a 
8 PHP 开 发 实战 宝 | 
Jee 二 Il 
和 PHP 网 络 编程 自学 手 ~ 


锁 入 要 跌 过 记录 的 编号 
《PHP 典 型 模块 》 后 网 络 编程 自学 于 几 》 


图 2.51 跳 过 数据 输出 中 指定 的 记录 
力 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 定义 一 个 数组 存储 数据 ， 然 后 定义 下 拉 列 表 ， 其 中 下 拉 列表 的 值 由 PHP 代 
码 动态 添加 ， 当 输入 跳 过 记录 的 编号 并 单 击 “ 跳 过 ”按钮 时 ， 利 用 continue 语句 ， 输 出 不 包含 指定 数据 的 其 他 
数据 ， 其 代码 如 下 : 


/定义 数组 
Sarray = array("PHP 典型 模块 "PHP 开发 实战 宝典 ""Java 开发 实战 宝典 "."PHP 网 络 编程 自学 手册 "); 


<form action="" method="pos 

<textarea name="te" ole="20 rows="6">0、<?php echo Sarray[0]:?> 1、 <?php echo $array[1]:?> 2、 <?php echo $array[2]:?> 
3、<?php echo Sarray[3]:?> 

</textarea><br> 

<input type="text" name="text" value=" 输 入 要 跳 过 记录 的 编号 "size="20" onFocus="this.value=""> 

<input type="submit" name="subl" value=" 跳 过 "> 


</form> 
<7 
if($_POST[sub1){ // 通 过 POST 方式 传递 参数 
for($a = 0;$a < count($array):$a++){f /| 循环 数组 
if($a — $_POST[text){ // 当 $a 等 于 文本 框 中 的 数据 时 回 到 循环 开始 位 置 
continue: 
Jelse{ 
& 各 
echo $array[$a]; /| 输出 数组 元 素 
echo » ie 
} 
} 
} 
> 
(2) 将 该 文件 存储 于 \MR\02\077 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.51 所 示 。 
图 秘笈 心 法 


心 法 领悟 077: 在 HIML 中 插入 PHP 代码 。 
PHP 代码 可 以 插入 到 HIML 页 面 的 任何 位 置 ， 也 可 以 插入 到 HTML 的 任何 一 个 可 行 性 标签 中 。 


环 


力 实例 说 明 
本 实例 利用 break 语句 实现 执行 指定 次 数 的 循环 ， 运 行 结果 如 图 2.52 所 示 。 
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7 


已 经 输出 1 次 循环 
已 经 输出 2 次 循环 
已 经 输出 3 次 循环 守 浊 


2.52 ”执行 指定 次 数 的 循环 


图 关键 技术 
本 实例 利用 break 语句 可 以 跳出 循环 并 终止 循环 的 特点 ， 控 制 循环 执行 的 次 数 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 当 单 击 “ 执 行 ”按钮 时 ， 首 先 ， 定 义 for 循环 语句 ， 设 定 循环 变量 $a 的 初始 值 


为 0， 并 且 每 执行 一 次 循环 ，$a 做 一 次 自 增 运算 。 然 后 ， 通 过 让 语句 定义 条 件 ， 如 果 $a 大 于 等 于 文本 框 中 输入 
的 数字 时 ， 跳 出 当前 循环 ， 否 则 输出 字符 串 ， 其 代码 如 下 : 
pl 


hp 
if($_POST[sub1D{ /通过 POST 方式 传递 参数 
for($a = 0;$a < 10000000000000:Sa++jf /循环 
这 $a >= $_POST[text){ // 接 收文 本 框 信息 判断 条 件 
break: /| 结束 循环 
Jelse{ // 否 则 循环 输出 


echo "已 经 输出 "($a+1)." 次 循环 <br>"; 
} 
} 


2> 


(2) 将 该 文件 存储 于 WMR\02\078 文件 夹 下 ， 命 名 为 index php。 运 行 结果 如 图 2.52 所 示 。 
图 秘笈 心 法 
心 法 领悟 078: 流程 控制 语句 。 


流程 控制 语句 包括 条 件 控制 语句 、 循 环 控制 语句 和 跳 转 控制 语句 ， 是 PHP 的 重要 组 成 部 分 也 是 PHP 程序 
员 必须 重点 掌握 和 理解 的 内 容 。 


2.7 自 定 义 函 数 


在 开发 过 程 中 ， 经 常 需要 多 次 重复 某 种 操作 或 处 理 ， 如 数据 查询 、 字 符 操作 等 。 如 果 每 个 模块 都 要 重新 输 
入 一 次 代码 ， 不 仅 加 大 了 程序 员 的 工作 量 和 开发 时 间 ， 而 且 对 于 代码 的 后 期 维护 及 运算 效果 也 有 很 大 影响 。 使 
用 自 定义 函数 就 是 解决 该 问题 的 最 有 效 的 方法 。 


实例 079 


力 实例 说 明 
截取 字符 串 在 程序 设计 中 是 经 常 出 现 的， 例如 ， 截 取 增 、 删 、 改 、 查 SQL 语句 的 前 6 个 字符 进行 判断 ， 以 便 
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进行 增 、 删 、 改 、 查 等 操作 。 本 实例 应 用 substr0 函 数 实现 用 自 定义 函数 截取 中 文字 符 串 ， 运 行 结果 如 图 2.53 所 示 。 


图 2.53 ” 自 定义 函数 截取 中 文字 符 串 


图 关键 技术 


substr0 函 数 用 于 从 字符 串 中 按照 指定 位 置 截 取 一 定 长 度 的 字符 ， 通 过 该 函数 可 以 获取 某 个 固定 格式 字符 串 
中 的 一 部 分 。 如 果 使 用 一 个 正 数 作为 子 串 的 起 点 来 调用 这 个 函数 ， 将 得 到 从 起 点 到 字符 串 结束 的 整个 字符 串 ; 
如 果 使 用 一 个 负数 作为 子 串 的 起 点 来 调用 ， 将 得 到 原 字符 串 尾部 的 一 个 子 串 ， 字 符 个 数 等 于 给 定 负数 的 绝对 值 。 


substrO 函 数 的 语法 如 下 : 
string substr ( string str, int start [, int length]): 


参数 str 用 来 指定 字符 串 对 象 ， 参 数 start 用 来 指定 开始 截取 字符 串 的 位 置 ， 如 果 为 负数 ， 则 从 字符 串 的 末 
尾 开 始 截取 ， 参数 length 为 可 选项 ， 指 定 截取 字符 的 个 数 ， 如 果 为 负数 ， 则 表示 截取 到 倒数 第 length 个 字符 。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 定 义 自 定义 函数 ， 当 单 击 “ 截 取 ” 按 钮 时 ， 利 用 substr0 函 数 对 指定 字符 串 进行 
截取 并 输出 蕉 取信 息 ， 其 代码 如 下 : 

es function strO{ // 自 定义 函数 str0 

if($_POST[sub){ // 通 过 POST 方式 传递 参数 
$a=" 自 定义 函数 截取 中 文字 符 串 我 是 被 截取 的 部 分 "， ” /定义 字符 串 变量 
S$rs = substr($a,(2+$_POST['text]-2).(2*$_POST['text_1"])); /截取 字符 串 

: echo S$rs; /输出 截取 结果 


strO; // 自 定义 函数 调用 


?> 
(2) 将 该 文件 存储 于 \MR\02\079 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.53 所 示 。 
国 秘笈 心 ; 


心 法 领悟 079: substr0 函 数 的 特点 。 
substr0) 函 数 支持 从 右 侧 取 值 ， 例 如 : 
<php 


$a ="abcdef"; /定义 字符 串 
Srs = substr($a.-2.1): /从 右 侧 取 值 
echo $rs; /输出 截取 结果 


> 
经 正 浏 览 器 运行 ， 显 示 结 果 为 e。 


力 实例 说 明 
本 实例 通过 字符 串 截取 函数 和 自 定义 函数 实现 公告 标题 的 截取 ， 运 行 结果 如 图 2.54 所 示 。 
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ow 


融雪 全 办 移 开 守 第 二 王 天 
南非 世界杯 正 进 行 的 如 火 如 茶 
二 Po 


图 2.54 公告 标题 的 截取 


图 关键 技术 


自 定义 函数 ， 顾 名 思 义 是 由 用 户 自 行 定义 并 完成 指定 功能 的 函数 。 自 定义 函数 的 产生 是 由 于 程序 员 在 进行 
日 常 开发 时 ， 使 用 PHP 预定 义 的 函数 并 不 能 实现 理想 的 功能 。 程 序 员 人 迫切 希望 能 够 根据 自己 程序 的 实际 情况 自 
行 定义 完成 指定 功能 的 函数 。 创 建 函 数 的 基本 语法 格式 如 下 : 


function fraction name ([$arg_1],[Sarg_ 2], … ,[Sarg_n]){ 


} 

参数 说 明 : 

function: 声明 自 定义 函数 时 必须 使 用 的 关键 字 。 

function_name: 创建 函数 的 名 称 ， 是 有 效 的 PHP 标识 符 。 函 数 名 称 是 唯一 的 ， 其 命名 遵守 与 变量 命名 相同 
的 规则 ， 只 是 不 能 以 “$” 开 头 。 

arg_1.…arg_n: 是 外 界 传递 给 函数 的 值 ， 可 有 可 无 ， 也 可 以 有 多 个 ， 数 量 根据 需要 而 定 ， 各 参数 用 逗号 “,” 
分 隔 。 参 数 的 类 型 不 必 指 定 ， 在 调用 函数 时 只 要 是 PHP 支持 的 类 型 都 可 以 使 用 。 

fun_body: 自 定义 函数 的 主体 ， 是 功能 实现 部 分 。 

retum: 将 调用 的 代码 需要 的 值 返 回 ， 并 结束 函数 的 运行 。 

在 本 实例 中 ， 定 义 自 定义 函数 str0， 地 和 中 行人， 其 语法 如 下 : 


function str($st) { 定义 函数 
$a = strlen($str); 人 
$b = substr($str,0,$a); 1/ 截取 字符 串 
echo $b: /输出 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 定 义 数组 ， 当 单 击 “获取 标题 ” 超 链接 时 ， 调 用 自 定义 函数 str0 对 数组 中 的 元 
素 进行 截取 ， 并 输出 截取 后 的 标题 信息 ， 其 代码 如 下 : 
<7 


// 定 义 数组 
Sarray = array(" 南 非 世界 杯 开赛 第 十 五 天 "." 南 非 世界 杯 正 进行 得 如 火 如 茶 ， 头 号 种 子 队伍 巴西 戏 勇 善战 ， 取 得 了 良好 成 绩 。"); 
?> 


<table border="1" bordercolor="#CCCCCC"cellspacing="0" width="290" height="251" align="center” background-"2.jpg"> 
<tr><td width="208" align="center"> 
<b style="font-family: 文 易 霹 雳 体 : font-size:18px; color:#0033CC"><?php echo $array[0]:?></b><br> 
<b style="font-family:' 方 正 新 报 宋 简体 '; font-size:14px: color#0033CC">&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:<?php echo 
Saray[1]:?></b><br> 


<a hre 人 "index.php?sub= 获 取 " style="float:center"> 获 取 标 题 </a> // 定 义 超 链接 
<htd> 
</tr><tr><td align="center"><b style="color:#F0000; font-family:' 方 正 细 圆 繁体 "> 
<?php 
这 $_GET[sub] 一 "获取 "){ // 通 过 GET 方式 获取 参数 


ls 


str(Sarmray[0]): 
} 


function str($str) { 
$a = strlen($str); 
Sb = substr($str,0,5a); 
echo $b: 

} 


?> 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


// 调 用 自 定义 函数 


// 自 定义 函数 

1/ 计算 字符 串 长 度 
// 截 取 字 符 串 
/输出 


(2) 将 该 文件 存储 于 \MR\02\080 文件 夹 下 ， 命 名 为 index php。 运 行 结果 如 图 2.54 所 示 。 


心 法 领悟 080: 自 定义 函数 的 应 用 注意 事项 。 


自 定义 函数 的 名 称 是 不 区 分 大 小 写 的 ， 而 常量 和 变量 的 名 称 区 分 大 小 写 。 


力 实例 说 明 


ea 


高 级 | 


赵 味 指数 ， 寅 查 宙 宣 | 


开发 论坛 程序 很 重要 的 一 点 是 转换 空格 符 和 回 车 符 , 因为 不 是 所 有 的 论坛 用 户 都 知道 HTML 标签 “&nbsp;” 
和 <br> 的 作用 ， 大 多 数 用 户 都 喜欢 用 空格 和 回 车 对 文本 进行 控制 ， 这 就 需要 程序 员 人 为 地 做 到 统一 。 本 实例 通 
过 自 定义 函数 定义 转换 方法 实现 论坛 内 容 的 简短 输出 ， 运 行 结 果 如 图 2.55 所 示 。 


力 关键 技术 


标题 下 
TI 编程 你 好 
PHP 编 程 


内 容 : | [RE 
提交 + 


AORsE/ 
标题 :PHP 
内 容 : PEP 编 程 ` 你 好 P 王 编程 谢谢 您 


2.55 ”论坛 内 容 的 简短 输出 


本 实例 通过 自 定义 函数 实现 对 字符 串 中 空格 符 和 回 车 符 的 转换 输出 ,在 自 定义 函数 中 应 用 的 是 preg_replaceO 


函数 。 自 定义 函数 的 语法 如 下 : 
function str($st) { 


Sstr = preg_replace("/ /"."&nbsp:",$str); 
Sstr = preg_replace("/cha(13)/","<br>".$str): 


echo "内 容 : ".$str; 
} 


力 设计 过 程 


// 自 定义 函数 
// 普 换 空格 

// 普 换 回 车 符 
/输出 


(1) 创建 PHP 脚本 文件 ， 通 过 自 定义 函数 定义 对 “&nbsp;” 和 回 车 进行 蔡 换 ， 当 单 击 “提交 ”按钮 时 ， 
首先 对 文本 框 是 否 存在 内 容 进行 判断 ， 如 果 文本 框 内 容 不 为 空 ， 调 用 自 定义 函数 并 输出 文本 信息 ， 其 代码 如 下 : 
< 


hp 
function str($str){ 


Sstr = preg_replace("/ /"."&nbsp:".$str): 
Sstr = preg_replace("/cha(13)/","<br>".$str); 


echo "内 容 : ".$str; 


} 
isS_POST[sub]){ 


/如 果 text 为 空 或 者 文本 域 和 下 拉 列 表 框 同时 为 空 
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// 自 定义 函数 
// 莹 换 空格 

// 普 换 回 车 符 
/输出 


// 通 过 POST 方式 传递 参数 


第 2 章 PHP 基础 


if($ 1 a 一 ”|(S_ POST[t] 一 ”) && ($_POST[check] — D){ 


echo "<script>alert( 内 容 不 能 为 空 ):location hre 人 index.php'</script>": /输出 提示 
jelsef 

这 $_POST[select] (= "1){ /当下 拉 列 表 框 值 不 等 于 1 时 
echo "标题 : ".$_POST[text]."<br>"; /输出 内 容 和 下 拉 列 表 框 内 容 
str($_POST[te].$_POST[check]); 

Jelse{ 
echo "标题 : ".$_POST[text]."<br>"; /否则 只 输出 文本 域内 容 
str($_POST[te]); 


} 
} 


(2) 将 该 文件 存储 于 \MR\02\081 文件 夹 下 ， 命 名 为 index php。 运 行 结果 如 图 2.55 所 示 。 
秘笈 心 法 
心 法 领悟 081， 对 于 实例 代码 的 重要 说 明 。 


上 例 代 码 中 “$_POST[text] = 一 "|| (($_POST[te] 一 "") && ($_ POST[check] 一 1))” 是 存在 运算 符 优先 级 的 ， 
为 了 避免 发 生 错 误 ， 笔 者 将 先进 行 的 运算 加 上 了 小 括号 。 


EO i 
ee | 
国 实例 说 明 


用 户 在 论坛 上 发 表 或 者 回复 留言 时 可 能 会 遇 到 这 种 情况 ， 单 击 “ 发 布 ”按钮 时 ， 系 统 提示 使 用 了 禁用 词语 ， 
禁止 发 布 。 这 是 论坛 的 开发 人 员 为 了 规范 论坛 而 采用 的 过 滤 字 符 串 的 手段 。 本 实例 通过 自 定义 函数 实现 过 滤 字 
符 串 ， 运 行 结 果 如 图 2.56 所 示 。 


图 2.56 自 定义 函数 过 滤 字 符 串 


图 关键 技术 
本 实例 编写 自 定义 函数 str0 对 字符 串 进行 过 滤 ， 如 果 出 现 指定 的 关键 词 ， 则 给 出 提示 信息 并 终止 程序 执行 。 
自 定义 函数 str0) 的 语法 如 下 : 
function str($str) { 
$array = array(' 图 书 ', 明 日 科技 ,软件 ,编程 词典 ,编程 词典); /定义 数组 
Srepstr = implode($array): // 数 组 转换 成 字符 串 
ifpreg 1 mete Srepstr){ // 正 则 表达 式 验 证 字符 串 
echo "<seript>alert(' 您 使 用 了 禁用 词语 ， 请 重新 填写 ):location hre 全 index.php'</script>"; 
jslse{ 
echo "内 容 为 : ".$str: // 输 出 数据 
} 
} 


ul 


PHP 开发 实例 大 全 (基础 卷 ) 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 定义 自 定义 函数 ， 将 禁用 词语 保存 在 数组 中 ， 并 通过 字符 串 函数 拆 分 数组 ， 


利用 正则 表达 式 函数 对 禁用 词语 进行 屏蔽 。 当 单 击 “提交 ”按钮 时 ， 调 用 自 定义 函数 对 提交 内 容 进 行 过 滤 ， 并 
输出 提示 信息 ， 其 代码 如 下 : 


<?php 
function str($str){ 
$array = array(' 图 书 ',' 明 日 科技 ,软件 "编程 词典 "编程,' 词 典 ); // 定 义 数组 
Srepstr = implode($array); // 数 组 转换 成 字符 串 
iflpreg_match("/$str/", Srepstr){ // 正 则 表达 式 验证 字符 串 
echo "<seript>alert( 您 使 用 了 禁用 词语 ， 请 重新 填写 ):location href="index.php'</script>"; 
Jelse{ 
echo "内 容 为 :".$str; /输出 数据 
} 
if($_POST[sub){ 
str($_POST[te]); // 调 用 自 定义 函数 


2> 


(2) 将 该 文件 存储 于 \MR\02\082 文件 夹 下 ， 命 名 为 index php。 运 行 结果 如 图 2.56 所 示 。 
图 秘笈 心 法 


心 法 领悟 082: 过 滤 程 序 。 
本 实例 只 是 简单 地 介绍 了 字符 串 过 滤 的 原理 ， 真 正 的 过 滤 程 序 由 于 数据 量 较 大 ， 需 要 将 数据 存储 在 数据 库 
中 。 如 果 读 者 感 兴趣 ， 可 以 将 其 与 数据 库 中 的 数据 结合 使 用 。 


2.8 字 符 串 


在 许多 Web 编程 中 ， 字 符 串 总 是 会 被 大 量 地 生成 和 处 理 。 正 确 地 使 用 和 处 理 字符 串 ， 对 于 PHP 程序 员 来 
说 越 来 越 重 要 。 


趣味 指数 : 伍 食 福全 


实例 083 


力 实例 说 明 


由 于 各 个 用 户 所 使 用 的 输入 法 不 同 或 者 个 人 习惯 的 原因 ， 有 可 能 不 经 意 间 多 输入 了 空格 或 者 特殊 字符 ， 造 
成 网 站 内 容 的 输出 不 美观 。 本 实例 通过 ltrim0 和 rtrim0 函 数 实现 去 除 字符 串 中 的 空白 和 特殊 字符 ， 运 行 结 果 


如 图 2.57 所 示 。 
和 中 区 昌 
去 除 字 符 申 二 你 好 VPHP 东 秽 
2.57 去除 字符 串 中 的 空白 和 特殊 字符 
图 关键 技术 
(1) ltrim0 函 数 


使 用 ltim0 函 数 默认 情况 下 去 除 左边 空格 ， 去 除 特殊 字符 的 参数 可 选 。 
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string ltrim ( string str [, string charlist]); 
参数 说 明 : 
string str: 源 字符 串 信 息 。 
string charlist: 可 选 参数 ， 特 殊 字符 。 

(2) rtrim0 函 数 
使 用 rtrim0 函 数 默 认 情 况 下 去 除 右边 空格 ， 去 除 特殊 字符 的 参数 可 选 。 
string rtrim ( string str [, string charlist]); 
参数 说 明 : 
string str: 源 字 符 串 信息 。 
string charlist: 可 选 参数 ， 特 殊 字符 。 


图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 定 义 字符 串 变量 Sa, 分别 通过 ltrim() 和 rtrim() 函 数 去 除 两 边 的 空格 和 特殊 字符 并 
显示 结果 ， 其 代码 如 下 : 


<php 
$a="(:@_@ 你 好 ! PHP 范例 @_@:)"; // 声 明 一 个 带 空格 和 特殊 字符 的 字符 串 变量 
Sb = ltrim($a); // 去 除 变 量 左 边 的 空格 
$c=1tim($b,"(:@_@"); // 去 除 变量 左边 的 特殊 字符 
Sd =rtrim(Se); // 去 除 变 量 右边 的 空格 
Se=rtrim($d,"@ _@:)"): // 去 除 变 量 右边 的 特殊 字符 
echo "去 除 字符 串 空白 和 特殊 字符 前 : ".$a."<br>"; 
echo "去 除 字符 串 空白 和 特殊 字符 后 : "Se; /输出 最 后 结果 
?> 
(2) 将 该 文件 存储 于 \MR\02\083 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.57 所 示 。 
图 秘笈 心 法 


心 法 领悟 083: 使 用 ltrim0 和 rtrim0 函 数 的 相关 说 明 。 
在 使 用 这 两 个 函数 时 ， 默 认 情 况 下 是 只 去 除 左边 或 者 右边 的 空格 ， 想 要 去 除 特殊 字符 ， 需 要 在 函数 里 注 明 。 


实例 084 


趣味 指数 : 依依 依依 


国 实例 说 明 


论坛 帖子 中 的 单 引号 和 双 引 号 在 未 经 转 义 的 情况 下 输出 会 出 现 问 题 ,特别 是 在 输出 SQL 语句 时 。 本 实例 通 
过 addslashes0 函 数 来 实现 转 义 字符 串 ， 运 行 结果 如 图 2.58 所 示 。 


未 经 转 头 的 字符 申 玫 P! 入 语句 归 INstRi"TNio + ,yA TY ) 
经 转 义 后 的 字符 帅 入 语句 s INSERTy INTD +t IE VALUBS OMN, Yonigline\ 


2.58 ” 转 义 字符 串 


力 关键 技术 


本 实例 主要 是 通过 addslashesO) 函 数 对 指定 的 SQL 语句 进行 自动 转 义 。addslashes() 函 数 可 以 转 义 单 引 号 、 双 
引号 、 反 斜 本 、NULL 字符 ， 主 要 用 于 SQL 语句 ， 对 部 分 字符 进行 转 义 ， 其 语法 如 下 : 

string addslashes ( string str); 

参数 说 明 : 

string str: SQL 语句 。 
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图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 定义 插入 型 SQL 语句 ， 然 后 将 SQL 语句 通过 addslashes0 函 数 转 义 并 显示 


转 义 结果 ， 其 代码 如 下 : 
<?php 


$str = "INSERT INTO db(iduserpwdjlast_dateJVALUES(1,yangv*yysy.2010-06-03)": 。“// 声 明 一 个 字符 串 变量 
echo "未 经 转 义 的 字符 串 :".$str."<br>"; // 未 经 转 义 
echo "经 转 义 后 的 字符 串 : ".addslashes($str); /| 经 转 义 

Ss 


(2) 将 该 文件 存储 于 WMR\02\084 文件 夹 中 ， 命 名 为 index php。 运 行 结果 如 图 2.58 所 示 。 


心 法 领悟 084: addslashes0 函 数 在 程序 中 的 应 用 。 
addslashes0 〇 函数 主要 用 于 数据 库 SQL 语句 的 转 义 ， 当 数据 要 插入 至 数据 库 之 前 ， 有 必要 应 用 addslashes( 
函数 进行 字符 串 转 义 ， 以 免 特殊 字符 未 经 转 义 在 插入 数据 库 时 出 现 错误 。 


高 级 | 


实例 085 趣味 指数 ， 宙 本 女 刘 ， 


图 实例 说 明 


既然 可 以 将 帖子 内 容 进行 转 义 ,当然 也 可 以 将 帖子 内 容 进行 还 原 。 本 实例 通过 stripslashes0 函 数 来 实现 还 原 
字符 串 ， 运 行 结果 如 图 2.59 所 示 。 


未 经 还 原 的 字符 钊 。 入 性 梧 全 INSERTIOINID + ,yAL ESN , ns\ 午 
经 还 原 后 的 字符 帅 : 入 语句 s INSERT/INID +t ,rae VAL IESC WO Y ) 


图 2.59 还 原 字符 串 


力 关键 技术 


本 实例 运用 stripslashesO 函 数 ， 将 addslashes0 函 数 转 义 的 字符 串 进行 还 原 ， 其 语法 如 下 : 
string stripslashes ( string str); 

参数 说 明 : 

string str: SQL 语句 。 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 首 先 定义 数据 库 插入 语句 的 字符 串 变 量 ， 然 后 将 字符 串 变 量 通过 stripslashesO 
函数 还 原 并 显示 运行 结果 ， 其 代码 如 下 : 

<2php 


$str = "INSERT INTO db(id.user.pwd .last_date)VALUES('1'.yang'.******"'2010-06-03”)"; 。“ // 声 明 一 个 字符 串 变 量 


echo "未 经 还 原 的 字符 串 : ".$str."<br>"; /未 经 还 原 字符 串 输出 
echo "经 还 原 后 的 字符 串 : ".stripslashes($str)."<br>"; /| 经 还 原 后 的 字符 串 输 出 
?> 
(2) 将 该 文件 存储 于 \MR\02\085 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.59 所 示 。 
图 秘笈 心 法 


心 法 领悟 085: stripslashes0 函 数 的 应 用 。 
stripslashes() 函 数 主要 用 于 数据 库 SQL 语句 的 还 原 输出 。 
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实例 086 


图 实例 说 明 
本 实例 通过 substr0 函数 实 现 截取 论坛 标题 ， 运 行 结果 如 图 2.60 所 示 。 
| 起 取 论坛 标题 | 
本 论坛 标题 ;s 截 取 论 坛 
截取 的 字符 囊 ;e 截取 论 
图 2.60 截取 论坛 标题 
图 关键 技术 


substr() 函 数 用 于 从 字符 串 中 按照 指定 位 置 截取 一 定 长 度 的 字符 ， 通 过 该 函数 可 以 获取 某 个 固定 格式 字符 串 
中 的 一 部 分 。substr0 函 数 的 详细 讲解 请 参见 实例 079。 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 定义 变量 $a 并 将 网 页 标题 赋 给 Sa， 然后 通过 substr0 函 数 对 字符 串 $a 进行 堆 
取 ， 并 输出 截取 内 容 ， 其 代码 如 下 : 

<?php 


$b = "截取 论坛 标题 "; // 设 定 字符 串 
$a = "<title>$b</title>"; // 设 定 网 页 标题 
echo $a; /输出 字符 串 
echo "本 论坛 标题 :".$b."<br>"; /输出 论坛 标题 
$b = substr($b.0.12); /截取 论坛 标题 
echo "截取 的 字符 串 :".$b; /| 输 出 截取 内 容 


> 


(2) 将 该 文件 存储 于 WMR\02\086 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.60 所 示 。 
国 秘笈 心 法 
心 法 领悟 086: substr0 函 数 应 用 的 注意 事项 。 


substr() 函 数 的 参数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 串 中 的 第 1 个 字符 表示 为 0。 该 函数 在 截取 
中 文字 符 串 时 可 能 会 出 现 乱码 ， 所 以 建议 在 对 中 文字 符 串 进行 截取 时 应 用 mb_substr0 函 数 。 


图 实例 说 明 


字符 串 的 分 割 、 合 成 对 于 程序 员 来 说 是 十 分 重要 的 ， 应 用 也 十 分 广泛 。 例如， 在 遍历 数据 库 查找 匹配 项 时 
就 会 用 到 合成 函数 ， 而 购物 车 程序 一 般 会 用 到 分 割 函数 。 本 实例 通过 explode0 函 数 和 implode0 函 数 实现 分 割 、 
合成 字符 串 ， 运 行 结果 如 图 2.61 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


原 字 符 串 ， 你 好 PHEN 很 你 。 
经 分 割 后 的 数组 为 ] => 你 好 PHP 丰 ] 六 很 你 .0 
合成 后 的 字符 串 2 你 : < 认识 你 = 


图 2.61 分割、 合成 字符 串 


图 关键 技术 


字符 串 的 分 割 与 合成 应 用 的 是 explode0 函 数 和 implodeO 函 数 。 
(1) explode0 函 数 


explode0) 函 数 按照 指定 的 规则 对 一 个 字符 串 进行 分 割 ， 返 回 值 为 数组 ， 其 语法 如 下 : 

array explode ( string separator, string string [, int limit]); 

参数 separator 表示 指定 的 分 隔 符 ，string string 表示 分 割 条 件 ，int limit 表示 指定 生成 数组 的 最 大 值 。 
(2) implodeO 函 数 

implode() 函 数 与 explodeO 函 数 配合 使 用 ， 将 数组 的 内 容 组 合成 一 个 字符 串 ， 其 语法 如 下 : 


string implode ( string glue, array picees]: 


参数 glue 是 字符 串 类 型 ， 指 定 分 隔 符 ， 参 数 pieces 是 数组 类 型 ， 指 定 要 被 合并 的 数组 。 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 定义 字符 串 变量 ， 将 字符 串 内 容 用 指定 的 分 隔 符 分 隔 。 然 后 利用 explode0 


函数 ， 将 字符 串 变 量 按照 规定 的 分 隔 符 分 割 ， 并 保存 在 数组 变量 $explode 中 。 最 后 分 别 利用 prinr r0 函 数 和 
implode0 函 数 输出 数组 和 字符 串 ， 其 代码 如 下 : 


<?php 


$str =" 你 好 PHP 很 高 兴 认识 你 。": /定义 字符 串 

$explode = explode(" ".$str); // 分 割 字符 串 

echo " 原 字符 串 ; "$str."<br>"; /输出 原 字符 串 

echo "经 分 割 后 的 数组 为 “: 

print_r(Sexplode); // 打 印 分 割 后 的 数组 

echo "<br> 合 成 后 的 字符 串 :"; 

echo implode($explode); // 将 数组 合成 为 字符 串 
> 


(2) 将 该 文件 存储 于 \MR\02\087 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.61 所 示 。 
图 秘笈 心 法 


心 法 领悟 087: explode0 函 数 和 implode0 函 数 哪个 应 用 更 广泛 。 
二 者 相 比 ，implode0 函 数 应 用 相对 广泛 ， 所 有 的 数组 变量 都 可 以 用 它 进行 


中 


成 。 


实例 088 


趣味 指数 : 二 全 真相 | 


力 实例 说 明 


关键 字 描 红 技术 广泛 应 用 于 站 内 搜索 或 者 高 级 搜索 中 ， 是 一 项 很 常用 的 技术 。 本 实例 通过 str_replace0 函 数 
实现 查询 关键 字 描 红 ， 运 行 结 果 如 图 2.62 所 示 。 


122 


第 2 章 PHP 基 础 


oogle_ Yahoo: 
! 


2.62 ”查询 关键 字 描 红 


图 关键 技术 
str_replace 0) 函数 可 用 于 执行 字符 串 蔡 换 操作 ， 其 语法 如 下 : 


mixed str replace ( mixed scarch mixed replace, mixed subject [, int &count] ) 
参数 说 明 : 

search: 必要 参数 ， 指 定 需 要 查找 的 字符 串 。 

replace: 必要 参数 ， 指 定 蔡 换 的 值 。 

subject: 必要 参数 ， 指 定 查找 范围 。 

count， 可 选 参数 ， 获 取 执 行 蔡 换 的 数量 。 


力 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 搜 索 ” 按 钮 时 ， 将 通过 POST 方式 接收 到 数据 ， 首 先 对 数据 进行 描 红 
处 理 ， 然 后 应 用 str_replaceO 函 数 对 指定 字符 串 信息 的 指定 内 容 进行 蔡 换 ， 其 代码 如 下 : 


<2php 


if($ POST[subD{ 
$a = "<b style='color:red;font-size:18px:>".$_POST[text]."</b>"; // 对 提交 的 关键 字 进行 描 红 
echo str_replace("$_POST[text]",$a,Sstr); /完成 字符 串 的 普 换 操作 
?> 


(2) 将 该 文件 存储 于 \MR\02\088 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.62 所 示 。 
图 秘笈 心 法 


心 法 领悟 088: 更 多 实现 关键 字 描 红 的 函数 。 
不 仅 可 以 通过 str_replaceO) 函 数 实现 关键 字 的 描 红 操作 ， 还 可 以 通过 str_ireplace0 函 数 实现 对 关键 字 的 描 红 
功能 ， 并 且 该 函数 不 区 分 大 小 写 。 


实例 089 


趣味 指数 : 袜 食 食 伍 


国 实例 说 明 
在 站 内 搜索 中 ， 往 往 要 求 列 出 符合 条 件 的 关键 字 有 多 少 个 。 本 实例 通过 字符 串 函 数 substr_count0 统 计 查询 
关键 字 出 现 的 次 数 ， 运 行 结果 如 图 2.63 所 示 。 


被 袖 索 的 文本 sw Pi 
网 公司 5oogle， 


和 寓 索 | pf A nh : NA 2006 芝 万 个 动态 网站 垃 用 
hbo, eBey 并 
其 键 字 ，| 
De ea 1 pe A ti ey 


shoo、s8ay 和 电 屋 知 记 况 站 拜访 、 百 度 、 同 里 已 四 条 
居 楼 宇 出 现 2 次 = > = 


2.63 估计 查询 关键 字 出 现 的 次数 


PHP 开发 实例 大 全 (基础 卷 ) 


图 关键 技术 
本 实例 通过 substr_ count0 函 数 检索 字符 串 子 串 出 现 的 次 数 。substr_count0 函 数 的 语法 如 下 : 


int substr_count ( string haystack, string needle ) 
参数 说 明 : 

string haystack: 源 字符 串 。 

string needle: 字符 串 子 串 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 , 首先 定义 字符 串 变 量 , 编写 form 表单 。 当 单 击 “ 搜 索 ” 按 钮 时 , 利用 substr_count() 
函数 输出 指定 字符 串 子 串 的 出 现 次 数 ， 其 代码 如 下 : 
~ echo "<a style='font-size:20px; color:#000000> 被 搜索 的 文本 : </a>"; // 定 义 字符 串 输出 


$str = "PHP 作为 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 ， 从 1994 年 诞生 至 今 已 被 2000 多 万 个 动态 网 站 采用 ， 全 球 知名 
互联 网 公司 Google、Yahoo、eBay 和 中 国 知 名 网 站 新 浪 、 百 度 、 阿 里 巴巴 等 均 采用 PHP 技术 ! "; 


echo $str."<br>"; 
?> 
<form action ="" method="post"> /表单 
关键 字 ， <input type="text" name="text"><input type="submit" name="sub" value =" 搜 索 "> 
</form> 
</body> 
</html> 
<?php 
ee /通过 POST 方式 传递 参数 
= "<b style='color:red:font-size: 18px:>".$_POST[text]."</b>"; // 普 换 后 的 字符 串 
人 :replace("$_POST[text]",$a,$str)."<br>"; // 莹 换 字符 串 
// 统 计 关键 字 出 现 次 数 


echo "关键 字 出 现 <b style='color:red:font-size:22px:>".substr_count($str,$_POST[text])."</b> 次 。"; 
} 


?> 
(2) 将 该 文件 存储 于 \MR\02\089 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.63 所 示 。 
图 秘笈 心 法 


心 法 领悟 089: substr_count0) 函 数 的 实现 原理 。 
substr_count0 函 数 是 一 种 类 似 全 文 检索 的 函数 ， 其 原理 是 检索 查找 匹配 的 字符 串 ， 返 回 匹 配 次 数 。 


图 实例 说 明 
文件 上 传 功能 几乎 是 所 有 网 站 所 必 备 的 ， 然 而 文件 上 传 对 于 服务 器 来 说 具有 很 大 风险 ， 因 此 应 该 对 文件 大 
小 、 文 件 类 型 进行 限制 。 本 实例 通过 字符 串 函数 strev0 获 取 上 传 文件 的 后 缀 ， 运 行 结果 如 图 2.64 所 示 。 
殿 键 字 jp: Vly Docments\ 范 例 大 [| 上 千 
后 缀 为 :doc 
图 2.64 获取 上 传 文件 的 后 缀 


趣味 指数 : 伍 广 寅 食 


转 关键 技术 
PHP 中 字符 串 的 逆序 输出 可 以 通过 循环 实现 ， 但 最 简单 的 方式 是 通过 strev0 函 数 实现 。strrev0 函 数 可 将 字 
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符 串 反 转 ， 其 语法 如 下 : 

string strrev (sting string ): 

参数 string 为 需要 反 转 的 字符 串 。 

在 本 实例 中 ， 通 过 strrev0 函 数 对 上 传 文件 的 名 称 进行 反 转 输 出 ， 并 通过 explode0 函 数 以 “.” 为 分 隔 符 ， 对 
文件 名 称 进行 分 割 ， 然 后 再 次 应 用 strrev0 函 数 对 数组 中 的 第 一 个 元 素 值 进行 返回 输出 ， 获 取 到 的 就 是 上 传 文件 
的 后 级 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 上 传 ”按钮 时 ， 首 先 利 用 POST 方法 接收 文本 框 中 的 信息 ， 然 后 利用 


反 转 函数 将 文本 框 信息 数据 进行 反 转 ， 并 利用 字符 串 拆 分 函数 以 “.” 进 行 分 割 ， 将 分 割 结果 保存 在 数组 中 。 最 
后 将 指定 数据 再 次 反 转 取得 并 输出 上 传 文件 的 后 缀 名 称 ， 其 代码 如 下 : 


php 
if($_POST[sub){ /通过 POST 方式 传递 参数 
$a = strrev($_ POST[text]): / 反 转 字符 串 
$b = explode(".",$a); /以 点 号 分 害 
$e = strrev($b[0]); /I/ 反 转 字符 串 
echo "文件 后 级 为 :.$e": /输出 文件 后 级 


} 
> 


(2) 将 该 文件 存储 于 \MR\02\090 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.64 所 示 。 
国 秘笈 心 ; 


心 法 领悟 090: 知识 扩展 。 
利用 strev0 函 数 检索 字符 串 相对 较 麻烦 ， 可 以 使 用 正则 表达 式 函 数 preg_match() 来 完成 该 功能 。 


力 实例 说 明 
统一 上 传 文件 名 称 的 大 小 写 是 十 分 必要 的 。 例 如 上 传 图 片 文件 img.jpg 和 Img.jpg， 如 果 文 件 名 称 未 经 大 小 

写 统一 ， 则 上 传 时 可 能 不 会 出 现 覆 盖 提 示 。 本 实例 通过 字符 串 函数 strtoupper0 和 strtolower0 实 现 统一 上 传 文件 

名 称 的 大 小 写 ， 运 行 结 果 如 图 2.65 所 示 。 

关键 字 ; snep eenr ees IEEE) 


文件 名 称 自 动 转换 为 
诡 件 名 称 自 动 转换 为 小 写 


2.65 ”统一 上 传 文件 名 称 的 大 小 写 


上 传 


力 关键 技术 


实现 字符 串 的 大 小 写 转换 ， 主 要 通过 strtolower0 和 strtoupper0 函 数 实 现 。 
(1) strtolower0 函 数 
使 用 该 函数 转换 为 小 写 。 


string strtolower ( string str ) 
(2) strtoupper0 函 数 


使 用 该 函数 转换 为 大 写 。 
string strtoupper ( string string ) 
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参数 string 为 需要 转换 的 字符 串 。 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 , 当 单 击 ^ 上 传 ?按钮 时 , 分 别 利用 转换 小 写 和 大 写 的 函数 strtolower0 和 strtoupper() 
将 接收 到 的 文本 框 信息 进行 对 应 的 大 小 写 转换 ， 并 输出 转换 结果 ， 其 代码 如 下 : 
<?pl 


if($_POST[sub){ 


// 通 过 POST 方式 传递 参数 


$a = strtoupper($_POST[text]): /| 转换 为 大 写 
echo "文件 名 称 自动 转换 为 大 写 : ".$a."<br>"; /输出 
Sb = strtolower($_POST[text]); /| 转换 为 小 写 
echo "文件 名 称 自 动 转换 为 小 写 :".S$b; /输出 


} 
> 


(2) 将 该 文件 存储 于 \MR\02\091 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.65 所 示 。 
国 秘笈 心 法 


心 法 领悟 091: strtolower0 和 strtoupper() 函 数 的 应 用 范围 。 
在 电子 商务 类 网 站 的 后 台 商品 添加 页 面 中 ， 为 了 使 商品 的 型 号 以 统一 的 规格 显示 ， 
函数 ， 所 以 掌握 这 两 个 函数 是 很 有 必要 的 。 


经 常会 使 用 大 小 写 转换 


实例 092 


趣味 指数 : 友 太 去 友 | 


力 实例 说 明 


在 论坛 文本 框 里 使 用 HTML 标签 是 存在 作用 效果 的 ， 但 是 对 于 论坛 管理 员 来 说 是 不 希望 看 到 的 ， 因 为 它 会 
给 服务 器 造成 压力 。 本 实例 通过 dassm nin 与 HIML 的 转换 ， 运 行 结果 如 图 2.66 所 示 。 


际 是 :人 FF 时 a Mr] : 2010-05:09 Pp 
区 了 了 了 


进行 了 转换 

<table border = '1' > > 标题 ; 经 济 半 小 时 <ytd 改 时 间 : 2010-063 
03< /td> </tr> <tr> < : 经 济 半 小 时 和 了解 中 | 节目 
</td> </tr></tabl 


图 2.66 字符 串 与 HTML 转换 


力 关键 技术 


PHP 中 使 HTML 代码 格式 化 输出 可 以 使 用 函数 htmlentities0 〇 实现 。htmlentities0 函 数 的 语法 如 下 : 
string htmlentities(string string,[int quote_style].[string charset]): 

参数 说 明 : 

string string: 需要 格式 化 输出 的 HTML 代码 。 

int quote_style: 可 选 参 数 ， 一 般 设置 为 ENT_QUOTES。 

string charset: 设置 编码 格式 。 


第 2 章 PHP 基础 


力 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 首 先 ， 定 义 字符 串 变量 ， 变 量 内 容 为 一 段 HTML 标签 (创建 表格 的 代码 ) 。 然 
后 ， 利 用 htmlentities0 函 数 将 字符 串 变量 进行 转换 并 输出 转换 结果 ， 其 代码 如 下 : 
2 echo "<h2> 没 有 进行 转换 </h2>"; 
$str = "<table border = '1><tr><td> 标 题 : 经 济 半 小 时 </td><td> 修 改 时 间 : 2010-06-03</td></tr><tr><td> 内 容 : 经 济 半 小 时 ， 了 解 中 国 经 济 最 好 的 


节目 <td></tr><ftable>"; // 定 义 HTML 格式 
echo $str /输出 字符 串 
echo "<h2> 进 行 了 转换 </h2>"; 
echo htmlentities($str, ENT_QUOTES."GB2312")."<br>"; /| 转换 HTML 


Wm. 


(2) 将 该 文件 存储 于 \MR\02\092 文件 夹 下 ， 命 名 为 index.php。 运 行 结 果 如 图 2.66 所 示 。 
力 秘笈 心 法 


心 法 领悟 092: 使 用 格式 化 函数 输出 的 优点 。 
格式 化 输出 HTML 可 以 直接 将 提交 的 源码 输出 并 确保 源码 不 被 解析 ， 从 而 可 以 确保 直接 在 页 面 中 输出 
HTML 标签 ， 而 不 被 解析 。 


m0% | 


力 实例 说 明 


统计 字符 串 长 度 一 般 是 为 了 给 其 他 函数 的 应 用 做 好 铺垫 。 本 实例 通过 strlen0 函 数 获取 帖子 标题 的 长 度 ， 运 
行 结果 如 图 2.67 所 示 。 


标题 。|PHP 编 入 宇和 
内 容 :|PHP 纺 程 宝典 好 


发 布 


本 长度 为 1 个 时 富 
图 2.67 统计 帖子 标题 的 长 度 


力 关键 技术 


strlen() 函 数 用 于 获取 字符 串 的 长 度 ， 其 语法 如 下 : 

int strlen ( string str); 

参数 说 明 : 

str: 指定 字符 串 。 
力 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 发 布 ”按钮 时 ， 利 用 strlen0) 函 数 获取 通过 POST 方式 接收 到 的 数据 长 
度 ， 其 代码 如 下 : 


这 $_POST[sub]){ /通过 POST 方式 传递 参数 
echo "标题 长 度 为 ".strlen($_POST[text)." 个 字 节 "; /获取 字符 串 长 度 
1 


?> 
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(2) 将 该 文件 存储 于 \MR\02\093 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.67 所 示 。 


心 法 领悟 093: 使 用 strlen0 函 数 的 注意 事项 。 
使 用 strlen0 函 数 获取 字符 串 长 度 时 ， 如 果 字符 串 中 存在 空格 ， 则 空格 也 会 被 计算 在 内 。 


A 高 级 | 
实例 094 起 叶枝 让 太太 
图 实例 说 明 


使 用 strlen0 函 数 可 以 统计 论坛 标题 的 长 度 ， 同 样 可 以 对 论坛 中 帖子 的 字 节 数 进行 统计 。 本 实例 通过 strlen0 
函数 对 论坛 中 帖子 的 字 节 数 进行 统计 ， 运 行 结果 如 图 2.68 所 示 。 
| 标题 ，PHP 纺 站 宝典 
ee 


图 2.68 计算 论坛 帖子 的 字 节 数 


图 关键 技术 


本 实例 同样 应 用 strlen0 函 数 统计 字符 串 的 长 度 ， 并 且 应 用 自 定义 函数 对 提交 的 源 代 码 进行 处 理 ， 保 证 源 代 


码 以 原形 式 输出 ， 而 不 会 输出 执行 文件 。 自 定义 函数 的 语法 如 下 : 
function unhtml($content){ 
S$content=htmlspecialchars($content); 
S$content=str_replace(chr(13),"<br>",$content); 
Scontent=str_replace(chr(32),"&nbsp;", $content); 
return trim($content); 


} 
图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 首 先 定义 自 定义 函数 ， 然 后 定义 字符 串 变 量 ， 接 着 应 用 strlen0 函 数 统计 帖子 内 
容 的 字 节 数 ， 并 且 通 过 自 定义 函数 对 帖子 内 容 进行 转换 ， 其 代码 如 下 ;: 
< 
unhtml($content){ 
Scontent=htmlspecialchars($content); 
S$content=str_replace(chr(13)."<br>",$content): 
S$content=str_replace(chr(32),"&nbsp:",$content); 
return trim($content); 
于 PHP 编程 宝典 <br> 内 容 : PHP 编程 宝典 非常 好 ! ": 
?> 
<table border="1" bordercolor="#FF0000" cellspacing="0"><tr><td> 
<?php echo $str:?> 
</td></tr></table> 
<php 
echo "共有 字 节 ".strlen(unhtml($str))." 个 "; 
bo 
(2) 将 该 文件 存储 于 \MR\02\094 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.68 所 示 。 
图 秘 签 心 法 


心 法 领悟 094: 自 定义 函数 unhtml0。 
自 定义 函数 unhtml0 主 要 用 于 对 提交 的 源 代码 进行 处 理 ， 保 证 源 代 码 以 原形 式 输出 ， 而 不 会 输出 执行 文件 。 
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力 实例 说 明 


用 微软 Windows 操作 系统 查找 文件 ， 可 以 使 用 CtrltF 快捷 键 实现 快速 定位 查找 。 本 实例 通过 strpos0 函 数 
模拟 这 一 功能 实现 定位 查找 ， 运 行 结果 如 图 2.69 所 示 。 
| 吉林 省 明日 科技 有 限 公司 是 二 家 以 计算 机 软件 技术 为 核心 型 企业 
[EEC 


计 林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核 科技 型 作业 
训 找 内 容 从 6 字 忆 开始 、 字符 虽 长 度 为 8 个 守节 pp xl 


图 2.69 实现 帖子 内 容 定位 查找 


图 关键 技术 
在 PHP 中 实现 特殊 字符 的 查找 和 定位 可 以 通过 stmpos0 函 数 来 实现 ， 函 数 语法 如 下 : 


int strops(string strl ,string str2, [int offset]) 
该 函数 的 作用 是 在 strl 中 查找 sttr2， 并 返回 查找 到 的 位 置 。strpos0 函 数 实现 的 原理 是 比较 整个 要 查找 的 字 
符 串 ， 并 返回 字符 串 str2 第 1 次 出 现 的 位 置 。 
力 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 定 位 查找 ”按钮 时 ， 首 先 定义 一 个 字符 串 变 量 Semail， 然 后 将 接收 到 的 
文本 框 数据 信息 进行 描 红 处 理 ， 最 后 利用 strpos0 函 数 实现 帖子 内 容 的 定位 查找 ， 其 代码 如 下 : 
如 这 $_POST[sub]){ 
Semail = ' 吉 林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 ': 
$str=$ POST[tel; 
$strl = "<b style='color:red:>".$str."</b>"; 
echo str_replace($str,$strl,Semail)."<br>"; 
a echo "查找 内 容 从 <b style='color:red;>".strpos($email,$str)."</b> 字 节 开 始 , 字符 串 长 度 为 <b style='color:red;>".strlen($str)."</b> 个 字 
下 
?> 


(2) 将 该 文件 存储 于 \MR\02\095 文件 夹 下 ， 命 名 为 ndex.php。 运 行 结果 如 图 2.69 所 示 。 
国 秘笈 心 法 


心 法 领悟 095: 知识 扩展 。 
strpos0 函 数 一 般 与 strlen0 函 数 联 合 使 用 ， 得 到 的 两 个 结果 相当 于 substr0 函 数 的 两 个 位 置 参数 。 


| 
实例 096 级 | 


a in *| 


力 实例 说 明 


用 户 在 编写 代码 时 也 许 会 在 不 经 意 间 多 输入 了 一 个 或 多 个 空格 ， 使 得 程序 无 论 怎么 调试 都 无 法 正常 运行 。 
本 实例 通过 trim0 函 数 实 现 去 除 帖 子 标题 的 首尾 空格 ， 运 行 结果 如 图 2.70 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


标题 | PEP 提交 
未 去 掉 空格 前 字符 长 度 节 
去 掉 空 格 后 宁 符 长 度 


图 2.70 ”去除 帖子 标题 的 首尾 空格 


图 关键 技术 


在 PHP 中 去 除 字符 串 的 首尾 空格 ， 可 以 使 用 函数 trim0 实 现 。trim0 函 数 的 语法 如 下 : 
string trim(string str); 

参数 说 明 : 

string str: 需要 过 滤 空 格 的 字符 串 。 


图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 当 单 击 “提交 ”按钮 时 ， 利 用 stlen0 和 tim0 函 数 的 联合 操作 ， 实 现 输出 去 除 首 
尾 空格 前 、 后 的 字符 串 的 长 度 ， 其 代码 如 下 : 

sphp 


if($_POST[sub){ /通过 POST 方式 传递 参数 
echo "未 去 掉 空格 前 字符 长 度 为 ".strlen($_POST[text])." 个 字 节 <br>"; /输出 结果 
echo "去 掉 空格 后 字符 长 度 为 ".strlen(trim($_POST[text])." 个 字 节 "; /输出 结果 
ee } 
(2) 将 该 文件 存储 于 \MR\02\096 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.70 所 示 。 
图 秘笈 心 ; 


心 法 领悟 096: 知识 扩展 。 
PHP 还 提供 有 单纯 去 除 字符 串 左边 或 者 右边 空格 的 函数 ， 详 细 说 明 参 见 实例 083。 


人 i | 
实例 | 
so oa st 
实例 说 明 
货币 数据 不 同 于 整 型 数据 ,其 是 存在 一 定格 式 的 。 本 实例 通过 number_format0 函 数 实现 金额 的 格式 化 输出 ， 


运行 结果 如 图 2.71 所 示 。 
清 输 出 多 入 557 一 
3,587.00 
图 2.71 金额 的 格式 化 输出 
图 关键 技术 


金额 的 格式 化 输出 通过 number format0 函 数 实现 ， 其 语法 及 说 明 如 下 : 

string number format ( float mumber ,int decimals) 

string number_format ( float number, int decimals, string dec_point, string thousands_sep) 

number format(O) 函 数 返 回 参数 number 格式 化 后 的 字符 串 ,该 函数 可 以 有 1 个 、2 个 或 4 个 参数 , 但 不 能 是 
3 个 参数 。 如 果 只 有 1 个 参数 number，number 格式 化 后 会 舍 去 小 数 点 后 的 值 ， 且 以 千 分 位 逗号 “,” 隔 开 ， 如 
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果 有 2 个 参数 , number 格式 化 后 会 到 小 数 点 第 decimals 位 , 且 会 以 每 一 千 喜 号 来 隔 开 ; 如 果 有 4 个 参数 , number 
格式 化 后 会 到 小 数 点 第 decimals 位 ，dec_point 用 来 替代 小 数 点 “.”，thousands_sep 用 来 蔡 代 每 一 千 隔 开 的 逗 
号 4” 。 
图 设计 过 程 

(1) 创建 PHP 脚本 ， 当 单 击 “ 格 式 化 ”按钮 时 ， 程 序 自动 将 文本 框 中 的 信息 进行 格式 化 ， 代 码 如 下 : 

2 is PosT[sobD{ /通过 POST 方式 传递 参数 


echo number_format($_POST[text].2): /格式 化 数字 
} 


?> 


(2) 将 该 文件 存储 于 \MR\02\097 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.71 所 示 。 
国 秘笈 心 法 


心 法 领悟 097: 函数 应 用 。 
开发 电子 商务 类 网 站 ， number format0 函 数 出 现 的 频率 是 百分之百 的 ， 所 以 掌握 此 函数 是 十 分 必要 的 。 


实例 098 


趣味 指数 : 址 食 食 三 


力 实例 说 明 


在 PHP 程序 设计 中 ， 经 常用 到 对 日 期 、 时 间 的 格式 化 输出 。 本 实例 通过 date0 函 数 实现 日 期 、 时 间 的 格式 
化 输出 ， 运 行 结 果 如 图 2.72 所 示 。 


显示 当前 9 期 时 间 2010-06-24 13:31:04 
图 2.72 日 期 、 时间 的 格式 化 输出 


图 关键 技术 

本 实例 的 关键 点 是 date0 函 数 的 灵活 运用 ， 详 细 说 明 详 见 实例 035。 
图 设计 过 程 

(1) 创建 PHP 脚本， 当 单 击 “ 显 示 当 前 日 期 、 时 间 ” 按 钮 时 ， 利 用 date0 函 数 根据 传 入 的 指定 的 参数 格式 
实现 格式 化 输出 ， 代 码 如 下 : 


<?php 
了 date_default_timezone_set("Asia/ShangHai"): /设置 时 区 
INS_GET[date] — D{ // 通 过 GET 方式 取得 参数 
echo date("Y-m-d H:i:s"): // 格 式 化 输出 时 间 和 日 期 
} 
?> 
(2) 将 该 文件 存储 于 \MR\02\098 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.72 所 示 。 
国 秘笈 心 法 


心 法 领悟 098: 获取 当地 时 间 。 
获取 当地 时 间 时 一 定 要 首先 设置 时 区 ， 和 否则 PHP 默认 使 用 的 是 英国 伦敦 的 零 时 区 ， 而 在 本 地 使 用 的 是 北京 
时 间 ， 即 东 八 区 的 时 间 。 设 置 时 区 时 ， 可 使 用 date_default_timezone_set("Asia/ShangHai") 语 句 。 
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实例 099 


力 实例 说 明 


在 论坛 程序 中 比较 两 个 帖子 是 否 相同 可 以 屏蔽 重复 帖子 ， 节 省 资源 空间 。 本 实例 通过 字符 串 函数 
similar textO 比 较 两 个 帖子 的 相似 度 ， 运 行 结果 如 图 2.73 所 示 。 


字符 让 1 与 字 行 陪 针 涉 学 节 和 且 ,相似 庆 oo 的 人 
Ca 


图 2.73 ” 比 对 论坛 中 帖子 的 相似 度 


力 关键 技术 
PHP 中 字符 串 相似 度 的 获取 可 以 通过 similar text0 函 数 来 实现 。 其 语法 格式 如 下 ; 


int similar text(sting strl,string str2,[double precent]) 
该 函数 用 于 比较 字符 串 strl 和 字符 串 str2 的 相似 程度 ， 函 数 的 返回 结果 是 字符 串 strl 和 字符 串 str2 的 相同 
字符 的 个 数 ， 而 可 省 参数 precent 的 值 是 这 两 个 参数 的 相似 度 。 


力 设计 过 程 
(1) 创建 PHP 脚本 ， 当 单 击 “ 比 较 ”按钮 时 ， 首 先 ， 分 别 获 取 字符 串 1 和 字符 串 2 中 的 数据 ， 然 后 ， 利 
用 字符 串 函数 simlar_text0 实 现 字符 串 相似 度 的 获取 ， 代 码 如 下 : 


<2php 
if($_POST[sub){ /通过 POST 方式 接收 参数 
$a = similar_text($_POST[te],$_POST[tex]); // 判 断 两 个 字符 串 的 相似 度 
if(strlen($_POST[te]) >= strlen($_POST[tex]){ 1/ 计算 百分比 


echo "字符 串 1 与 字符 串 2 有 ".$a." 个 字符 相同 .相似 度 为 ".($a/strlen($_POST[te])*100)."%6"; 
jelsef 
echo "字符 串 1 与 字符 串 2 有 ".$a." 个 字符 相同 .相似 度 为 ".($a/strlen($_POST[tex])*100)."%6"; 


} 


> 


(2) 将 该 文件 存储 于 \MR\02\099 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.73 所 示 。 
国 秘笈 心 法 


心 法 领悟 099: similar textO 函 数 的 原理 。 
similar textO 函 数 的 原理 是 对 应 比较 每 个 字 节 并 根据 结果 计算 百分比 。 


| 
ee 


趣味 指数 : 人 福 食 食 食 


实例 100 


力 实例 说 明 
对 于 电子 商务 网 站 的 用 户 来 说 ， 最 重要 的 就 是 账号 密码 的 安全 性 。 如 果 账 号 密码 未 经 过 加 密 处 理 ， 则 会 大 


第 2 章 PHP 基础 


大 增加 安全 隐患 ， 给 非法 用 户 以 可 乘 之 机 。 本 实例 是 通过 字符 串 函数 base64_encode0 和 base64 _decode0 实 现 对 
密码 的 加 密 和 解密 ， 运 行 结果 如 图 2.74 所 示 。 


用 记名 旨 jranming 
证 码 ep@@@e@eeeel 
[L 相 ] 


经 加 密 

用 户 名 :yangitirie 密 码 ca 
经 解密 

用 户 名 ，yangning 密 码 : :3591571301 


图 2.74 对 用 户 注册 的 密码 进行 加 密 和 解密 


力 关键 技术 


对 字符 串 的 base64 编码 可 以 通过 PHP 的 预定 义 函 数 base64_encode0 实 现 ， 其 语法 如 下 : 
string base64_encode(string str) 

该 函数 实现 对 字符 串 str 的 base64 编码 。 

对 已 经 进行 base64 编码 的 字符 串 进行 解码 用 函数 base64_decode0 实 现 ， 其 语法 如 下 : 


string base64_decode(string str) 
该 函数 实现 对 已 经 进行 base64 编码 的 字符 串 进行 解码 。 
图 设计 过 程 
(1) 创建 PHP 脚本 ， 当 单 击 “提交 ”按钮 时 ， 通 过 字符 串 函 数 base64_encode0 和 base64_decode0 实 现 对 
字符 串 的 加 密 和 解密 ， 代 码 如 下 : 
< 
we if($_POST[sub){ // 通 过 POST 方式 接收 参数 
echo "经 加 密 <hr>"; 
echo "用 户 名 : ".$_POST[text]; 


S$str = base64_encode($_ POST[pwd]): /对 密码 进行 加 密 
echo "密码 : ". $str; 


echo "用 户 名 : ".$_POST[text]; 
echo "密码 : ". base64_decode($str); /对 密码 进行 解密 
} 
> 
(2) 将 该 文件 存储 于 \MR\02\100 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.74 所 示 。 
力 秘笈 心 法 


心 法 领悟 100: 加 密 函 数 的 应 用 。 
base64_encode() 加 密 技术 在 邮件 系统 建设 等 方面 也 得 到 了 广泛 的 应 用 。 


力 实例 说 明 
表单 的 提交 方式 有 两 种 ，GET 方式 和 POST 方式 。GET 方式 属于 明文 地 址 栏 传 参 ， 存 在 安全 隐患 。 本 实例 
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通过 urlencode0 函 数 实现 保护 URL 地 址 中 传递 的 参数 ， 运 行 结 果 如 图 2.75 所 示 。 


当 attp:7/192.168.1 


文件 四 蝙 铝 上 查看 中 er RO Ey 


妨 址 @@) | 罗 http://192. 163.1. 59/mr/02/101/index. php?id+x3D+1 


Eeesns 由 由 | ， 汪 
四 .| © 妥 
图 2.75 保护 URL 地 址 中 传递 的 参数 
力 关键 技术 
PHP 中 字符 串 的 URL 编码 通过 urlencode() 函 数 实现 ， 其 语法 如 下 : 
string urlencode(string str) 
该 函数 实现 对 字符 串 str 的 URL 编码 。 
图 设计 过 程 


(1) 创建 PHP 脚本 ， 定 义 字符 串 变量 ， 将 此 字符 串 变 量 通过 urlencodeO) 函 数 进行 编码 ， 然 后 将 编码 后 的 
字符 串 变量 以 拼接 地 址 栏 参数 的 形式 定义 在 超 链接 中 ， 代 码 如 下 : 


$str="id=1"; // 定 义 字符 串 

$str = urlencode($str); // 对 字符 串 进行 编码 
We 
<a href="index.php?<?php echo $str:?>"> 对 地 址 栏 参 数 加 密 </a> /链接 


(2) 将 该 文件 存储 于 \MR\02\101 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.75 所 示 。 
图 秘笈 心 ; 
心 法 领悟 101: 知识 拓展 。 


经 编码 的 URL 参数 是 可 以 通过 urldecode0 函 数 进行 解码 的 ， 详 细 说 明 详 见 本 实例 。 即 使 不 对 URL 编码 后 
的 参数 进行 解码 ， 同 样 也 可 以 获取 到 传递 的 参数 值 。 


ER 
| 
实 斧 
实例 10 趣味 指教: | 
力 实例 说 明 
本 实例 通过 urldecode0 函 数 解析 URL 地 址 中 传递 的 参数 值 ， 运 行 结果 如 图 2.76 所 示 。 


人 http: //192. 168.1.59/ar/02/10275aEE php 
文件 中 编辑 中 明说 内 ”工具 帮助 0D 
捷 证 加 | 凶 http://lsz 163. 1 5a/ar/oz/lozyindex phpridxz0=xz0l 。 到 国 ] 苇 到 钴 六 辐 


er We 


TT Ov 加 
图 2.76 解析 URL 地 址 中 传递 的 编码 参数 


力 关键 技术 
对 已 经 进行 URL 编码 的 字符 串 进行 解码 使 用 urldecode0 函 数 ， 语 法 如 下 : 


string urldecode ( string str): 
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图 设计 过 程 

(1) 创建 PHP 脚本 。 首 先 ， 定 义 字符 串 变 量 并 为 此 字符 串 变 量 赋值 。 然 后 ， 将 字符 串 变 量 进行 URL 编码 
处 理 。 最 后 ， 单 击 超 链接 ， 并 将 链接 地 址 用 urldecode0 函 数 解码 ， 代 码 如 下 : 

<?php 


ET // 定 义 字符 串 
$str = urlencode($str); /对 URL 进行 编码 
$strl = urldecode($str); /对 URL 进行 解析 
?> 
<a href="index.php?<?php echo $str1:?>"> 对 地 址 栏 参数 解析 </a> /地 址 栏 传 参 
(2) 将 该 文件 存储 于 \MR\02\102 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.76 所 示 。 


心 法 领悟 102: URL 编码 是 否 可 以 应 用 于 防止 SQL 注入 。 
URL 编码 不 能 有 效 地 防止 SQL 注入 ， 原 因 在 于 URL 编码 可 以 解析 。 


Oe ee —— 
i 趣味 指数 : 二 三 福 全 | 
图 实例 说 明 


实例 043 已 经 向 用 户 介绍 过 “\” 转 义 特殊 字符 的 方法 。 下 面 通过 quotemeta0 函 数 实现 转 义 特殊 字符 ， 运 行 


结果 如 图 2.77 所 示 。 
转换 前 : A 
转换 后 \ 人 AN mingri 
2.77 “特殊 字符 的 转换 
图 关键 技术 
为 了 方便 特殊 字符 的 原样 输出 ，PHP 提供 了 quotemeta0 函 数 ， 其 语法 如 下 : 
string quotemeta(string str) 


该 函数 的 作用 是 在 字符 串 str 中 的 某 些 字符 前 面 加 上 反 斜 杠 “\”， 这 些 特殊 字符 主要 有 “.”、“\”、“+”、 
kp 、 “97 、 We 、 od i 、 Ap a fg 、 wp 、“$”， 其 中 ， 如 果 “$” 后 面 的 字符 与 “$” 共 同 构成 一 
个 合法 的 变量 名 ， 则 “S$” 前 不 加 “\”。 
图 设计 过 程 

(1) 创建 PHP 脚本 。 首 先 ， 定 义 字符 串 变量 并 将 一 系列 特殊 符号 赋 给 变量 。 然 后 ， 通 过 quotemeta0 函 数 

将 字符 串 变量 进行 转 义 输出 ， 代 码 如 下 : 

<Iphp 


$s="mingri": // 定 义 字符 串 变量 
$str="$.\+*?[]*O$s": // 定 义 字符 串 变 量 
echo" 转 换 前 "$str."<br>"; 
echo "转换 后 :".quotemeta($str); /| 转换 特殊 字符 
?> 
(2) 将 该 文件 存储 于 \MR\02\103 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.77 所 示 。 
力 秘笈 心 法 


心 法 领悟 103: 解决 无 法 原样 输出 字符 的 问题 。 
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在 进行 PHP 项 目 开发 过 程 中 ， 经 常会 遇 到 一 些 无 法 原样 输出 的 字符 ， 解 决 办 法 就 是 通过 转 义 字符 进行 
转 义 。 


高 级 


| 
Se | 
实例 104 起 听 指 数 : 寅 机 页 宽 wx 


力 实例 说 明 


敲 击 计算 机 键盘 上 的 任意 一 个 按键 都 要 经 过 ASCII 码 转换 后 显示 到 屏幕 上 。 本 实例 通过 字符 串 函 数 ord() 
实现 将 字符 转换 为 ASCI 码 ， 运 行 结果 如 图 2.78 所 示 。 


IE 


P 的 ASCII 码 为 ;80 
图 2.78 获取 任意 字符 的 ASCII 码 


图 关键 技术 
PHP 中 获取 字符 的 ASCII 码 应 使 用 ord0 函 数 ， 其 语法 如 下 : 
int ord ( string string); 
该 函数 预期 返回 一 个 整 型 数值 。 
图 设计 过 程 
(1) 创建 PHP 脚本 ， 当 单 击 “转换 ”按钮 时 ， 通 过 字符 串 函数 ord0 获 取 指定 字符 串 的 ASCII 码 ， 代 码 
如 下 : 
<?php 
这 $_POST[sub]){ // 通 过 POST 方式 传递 参数 
echo "$_ POST[text] 的 ASCII 码 为 : /输出 
echo ord($_POST[text]); WASCI 转 码 


} 
?> 
(2) 将 该 文件 存储 于 \MR\02\104 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.78 所 示 。 
图 秘笈 心 法 


心 法 领悟 104: 知识 拓展 。 
像 HTML 标签 “<br>” 等 都 可 以 在 ASCII 码 中 找到 相同 功能 的 ASCII 码 值 。 


高 级 | 
实例 | 
实例 105 趣味 指数 : 友 太 去 二 
图 实例 说 明 

本 实例 通过 字符 串 函数 chr0 实 现 将 ASCII 码 转换 为 字符 ， 运 行 结果 如 图 2.79 所 示 。 


112 转换 


2 的 ASCII 裙 为 


图 2.79 查找 指定 ASCII 码 对 应 的 字符 
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图 关键 技术 

将 ASCI[ 码 转 换 为 字符 可 以 通过 chr0 函 数 实现 ， 其 语法 如 下 : 

该 台数 可 将 ASCI 序数 值 转换 成 对 应 的 字符 ， 与 ord0 函 数 成 对 归 。 
图 设计 过 程 

(1) 创建 PHP 脚本 。 当 单 击 “ 转 换 ” 按 钮 时 ， 首 先 ， 利 用 POST 方法 获取 文本 框 中 传 入 的 数据 信息 ， 然 
SE chr0 函 数 转 换 为 ASCII 码 并 实现 输出 ， 代 码 如 下 : 


if($_POST[sub) { // 通 过 POST 方式 传递 参数 
echo "$_POST[text] 的 ASCI 码 为 :"; /输出 
echo chr($_POST[text]); //ASCII 对 应 的 字符 
网 } 
(2) 将 该 文件 存储 于 \MR\02\105 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.79 所 示 。 


心 法 领悟 105: ASCI 码 的 优点 。 
ASCII 码 在 程序 开发 中 的 使 用 相当 广泛 ， 在 某 些 时 候 将 字符 转换 成 ASCII 码 而 被 系统 识别 ， 既 能 保证 安全 
性 ， 又 能 获取 更 好 的 支持 。 


Es -的 名 称 高 级 | 
xn | ee 
力 实例 说 明 


为 了 使 上 传 文件 的 名 称 不 至 于 与 服务 器 已 有 文件 的 名 称 重 名 ， 合 理 定义 上 传 文件 的 名 称 就 显得 十 分 重要 。 
本 实例 通过 rand0O 函 数 合理 定义 上 传 文件 的 名 称 ， 运 行 结果 如 图 2.80 所 示 。 


园 一 个 贤人 rwms 


亿 择 上 传 文件 : |:\Docunents and Sett 有 HR 


上 传 图 片 大 小 为 (28 


文件 1284345109erestexnlhttp. js 上 传 成 功 ， 大 小 为 : 342 


Cd 


Copyright © 1999-2010 吉林 省 明日 科技 有 限 公司 


图 2.80 合理 定义 上 传 文件 的 名 称 


力 关键 技术 


在 PHP 中 应 用 move_uploaded_file() 函 数 实现 文件 的 上 传 。 但 是 在 执行 文件 上 传 之 前 , 为 了 防止 潜在 的 攻击 
对 原本 不 能 通过 脚本 交互 的 文件 进行 非法 管理 ， 可 以 先 应 用 is_uploaded file0 函 数 判断 指定 的 文件 是 不 是 通过 
HTTP POST 上 传 的 ， 如 果 是 ， 则 返回 TRUE。 
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(1) is_uploaded file0 函 数 
该 函数 用 于 判断 指定 的 文件 是 不 是 通过 HTTP POST 上 传 的 ， 其 语法 如 下 : 


boolis uploaded_ file ( string filename ) 
参数 filename 必须 指定 类 似 于 $_FILES['filename']['tmp_name'] 的 变量 ， 不 可 以 使 用 从 客户 端 上 传 的 文件 名 
$ FILES[filename'][name']。 
通过 is_uploaded file0 函 数 对 上 传 文件 进行 判断 , 可 以 确保 恶意 的 用 户 无 法 欺骗 脚本 去 访问 本 不 能 访问 的 文 
件 ， 例 如 /etc/passwd。 
(2) move uploaded file0 函 数 
使 用 该 函数 将 文件 上 传 到 服务 器 中 指定 的 位 置 。 如 果 成 功 返 回 TRUE， 否 则 返回 FALSE， 语 法 如 下 : 


bool move_uploaded_file ( string filename, string destination ) 

参数 filename 指定 上 传 文件 的 临时 文件 名 ， 即 $_FILES[tmp_name]; 参数 destination 指 文件 上 传 后 保存 的 新 
路 径 和 名 称 。 如 果 参 数 filename 不 是 合法 的 上 传 文件 , 不 会 出 现任 何 操作 ,move_uploaded_file() 将 返回 FALSE; 
如 果 参 数 filename 是 合法 的 上 传 文件 ， 但 由 于 某 些 原因 无 法 移动 ， 也 不 会 出 现任 何 操作 ，move_uploaded file0 
将 返回 FALSE， 此 外 还 会 发 出 一 条 警告 。 

(3) rand0 函 数 

使 用 该 函数 生成 的 随机 整数 作为 上 传 文件 的 新 名 称 。 


图 设计 过 程 
创建 index.php 文件 ,添加 表单 ,设置 文件 域 .提交 按钮 , 使 用 POST 方法 , 设置 enctype="multipart/form-data"， 
通过 $_FILES 获取 上 传 文件 的 相关 信息 ， 通 过 move_upload_file0 函 数 完成 图 片上 传 ， 其 代码 如 下 : 


<2php 
这 !empty($_FILES[up_picture][name])){ // 判 断 上 传 内 容 是 否 为 空 
if($_FILES['up_picture']['error >0){ // 判 断 文 件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错 误 :"; 
switch($_FILES[up_picture][error]){ 
case 1: 
ccho "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break; 
case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break; 
ase 3: 
echo "上 传 文件 不 全 ": 
break: 
case 4: 
echo "没有 上 传 文件 "; 
break: 
} 
Jelse{ 
(tis_dir("./upfile/") { // 判 断 指定 目录 是 否 存 在 
mkdir("./upfile/"); // 创 建 目录 
攻 
S$path= upfile/rand0.$_FILES[up_picture][name]: /定义 文件 名 称 和 存储 位 置 
ifis_uploaded_file($_FILES[wp_picture [tmp_name]){ // 是 不 是 HITP POST 上 传 
这 Imove_uploaded_file($_FILES[mp_picture'][tmp_name].$pathb)){ /执行 上 传 
echo "上 传 失 败 ": 
jslse{ 


echo "文件 "time0.$_FILES[up_picture][mame']." 上 传 成 功 ， 大 小 为 : "$_FILES[up_picture]['size']; 
。 
Jelse{ 
echo "上 传 文件 ".$_FILES['up_pictute"][name"]." 不 合法 ! "; 
} 
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心 法 领悟 106: 上 传 文件 的 命名 问题 。 
上 传 文件 如 果 和 已 有 文件 重 名 ， 文 件 可 能 会 相互 苦 换 ， 给 网 站 造成 损失 。 所 以 确保 上 传 文件 名 称 的 唯一 性 
是 非常 必要 的 ， 也 可 以 通过 time0 时 间 戳 来 定义 上 传 文件 的 名 称 。 


注册 密码 进行 加 密 高 级 | 


趣味 指数 : 依依 请 坪 | 


实例 107 


力 实例 说 明 


图 2.81 通过 异 或 方式 对 用 户 注册 密码 进行 加 密 


图 关键 技术 


通过 异 或 方式 对 字符 串 加 密 的 原理 : 当 一 个 字符 串 A 与 另 一 个 字符 串 B 进行 异 或 运算 后 会 产生 一 个 字符 
串 CC。 


力 设计 过 程 

(1) 创建 PHP 脚本 。 首 先 ， 定 义 字符 串 变 量 并 为 此 字符 串 变量 赋值 。 然 后 ， 通 过 异 或 方式 对 字符 串 变量 
进行 加 密 并 输出 加 密 结果 ， 代 码 如 下 : 

< 


php 
if($_POST[sub){ /通过 POST 方式 传递 参数 

Sstr = "0123456798"; /定义 字符 串 
echo "用 户 名 : ".$_POST[text]."<br>"; 
echo " 密 &nbsp:&nbsp: 码 : ".($_POST[pwd]^$str): // 异 或 加 密 

> 2 

(2) 将 该 文件 存储 于 \MR\02\107 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.81 所 示 。 

力 秘笈 心 法 


心 法 领悟 107: 比较 异 或 方式 与 md5 加 密 技术 。 
PHP 中 对 字符 串 加 密 的 方式 有 很 多 种 ， 如 md5 加 密 等 。 异 或 方式 与 md5 加 密 方式 的 本 质 区 别 是 mds 加 密 
后 不 能 解密 ， 异 或 方式 可 以 。 相 对 而 言 ，md5 加 密 更 加 安全 。 


高 级 | 


实例 108 趣味 指数 : loboiod 


力 实例 说 明 
网 站 的 国际 化 已 经 不 是 一 个 炙手可热 的 话题 ， 但 是 由 于 地 区 差异 ， 在 使 用 英文 填写 注册 信息 时 ， 首 字母 的 
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大 小 写 往往 得 不 到 统一 。 本 实例 利用 ucfirst0 函 数 实现 将 英文 注册 用 户 的 首 字母 统一 为 大 写 ,运行 结果 如 图 2.82 
所 示 。 


图 2.82 统一 英文 注册 用 户 首 字母 的 大 小 写 


力 关键 技术 


在 PHP 开发 中 , 定义 首 字母 大 写 的 方法 有 很 多 , 但 是 所 有 的 方法 都 没有 使 用 PHP 预定 义 函数 ucfirst0 简 单 。 
ucfirst0 函 数 的 语法 如 下 : 

string ucfirst ( string str ); 

参数 说 明 : 

string str: 定义 字符 串 。 


图 设计 过 程 

(1) 创建 PHP 脚本 。 当 单 击 “ 提 交 ” 按 钮 时 ， 首 先 利用 POST(O 方 法 获取 从 文本 框 传递 进来 的 数据 ， 然 后 
将 获取 的 数据 经 ucfirst0 函 数 转换 首 字母 大 写 ， 最 后 输出 经 转换 后 的 数据 ， 代 码 如 下 : 

<?php 


这 $_POST[sub]){ // 通 过 POST 方式 传递 参数 
$a=$_POST[text]: // 接 收 参数 
echo " 首 字母 统一 为 大 写 :"; 
echo ucfirst($a): /转换 单词 首 字母 
党 } 
(2) 将 该 文件 存储 于 \MR\02\108 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.82 所 示 。 
图 秘笈 心 法 


心 法 领悟 108: 知识 拓展 。 

实现 字符 串 首 字母 大 小 写 转换 还 可 以 通过 转 码 来 完成 。 首 先 利用 substr0 函 数 提取 出 字符 串 的 首 字母 ,之 后 
利用 ord0 函 数 获取 该 字母 的 ASCII 码 , 再 根据 大 小 写字 母 之 间 相 差 32 来 实现 大 小 写字 母 之 间 的 ASCII 码 转换 ， 
最 后 利用 chr0 函 数 将 转变 后 的 ASCII 码 转变 为 字母 即 可 。 
转换 高 级 | 


起 味 指数 : 宙 宙 页 页 


实例 109 


力 实例 说 明 
来 看 两 个 变量 $a = 123; 和 $a = '123';。 前 者 是 整 型 变量 ， 后 者 是 字符 型 变量 。 本 实例 利用 函数 使 字符 型 变量 
转换 为 整 型 变量 ， 整 型 变量 转换 为 字符 型 变量 ， 运 行 结果 如 图 2.83 所 示 。 


转换 前 类 型 为 :string 出 :123 
转换 后 输出 :123， 为 :integer 
转 光 前 类 型 为 “iiteger， 原 字 竺 素 输 出 : 123 


多 后 闪 出 : 123) 航 后 将 为 :string 
图 2.83 字符 串 与 数字 之 间 的 转换 


140 


第 2 章 PHP 基础 


图 关键 技术 
在 PHP 中 ， 将 数字 转换 为 字符 串 可 以 通过 strval0 函 数 实现 ， 其 语法 如 下 : 
string strval ( mixed var) 
该 函数 用 于 返回 变量 var 对 应 的 string 值 。 
图 设计 过 程 
(1) 首先 创建 脚本 文件 ， 定 义 字符 串 变量 并 将 数值 型 字符 串 赋 给 变量 ,然后 通过 strval0 函 数 转换 数据 ， 代 
码 如 下 : 
<?php 
S$str = "123"; // 定 义 字 符 串 
echo "转换 前 类 型 为 :".gettype($str); // 取 得 当前 数据 类 型 
echo "， 原 字符 串 输出 : ".$str; 
echo "<br>"; 
echo "转换 后 输出 : ".intval($str); // 将 字符 串 转换 为 整 型 
echo "， 转 换 后 类 型 为 :".gettype(intval($stn)); // 取 得 转换 后 的 数据 类 型 
echo "<hr>"; 
Sint = 123; // 定 义 整 型 变量 
echo "转换 前 类 型 为 ，".gettype(S$int); // 取 得 当前 类 型 
echo "， 原 字符 串 输出 :".$int; 
echo "<br>"; 
echo "转换 后 输出 : ".strval(Sint); /转换 为 字符 串 


echo "， 转 换 后 类 型 为 ，".gettype(strval(Sint); /输出 转换 后 的 数据 类 型 
Cy 将 该 文件 存储 于 \MR\02\109 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.83 所 示 。 
秘 敌 心 > 

心 法 领悟 109: 简 述 strval0 和 intval0 函 数 。 

strval0 和 intval0 函 数 在 实现 功能 上 与 强制 类 型 转换 机 制 相同 。 


, 和 i 0 | 
趣味 指数 : obokolodl| 
图 实例 说 明 


字符 串 匹 配 查 找 的 方法 有 很 多 ， 下 面 来 了 解 如 何 用 正则 表达 式 对 字符 串 进行 匹配 查找 。 本 实例 通过 数组 函 
数 和 正则 表达 式 函 数 preg_match() 来 实现 字符 串 的 匹配 查找 ， 运 行 结果 如 图 2.84 所 示 。 


f 


图 2.84 利用 正则 表达 式 实 现 字符 串 的 匹配 查找 


图 关键 技术 


灵活 运用 正则 表达 式 函 数 是 本 实例 的 关键 。preg_match0 函 数 用 于 匹配 指定 字符 串 ， 一 般 情况 下 ， 会 与 让 
条 件 语句 协同 使 用 ， 其 语法 如 下 : 


int preg_match ( string pattem. string subject [. array matches] ) 


函数 功能 : 在 字符 串 subject 中 匹配 表达 式 pattem。 函 数 返 回 匹 配 的 次 数 。 如 果 有 数组 matches， 那 么 每 次 
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匹配 的 结果 将 被 存储 到 数组 matches 中 。 该 函数 在 匹配 成 功 后 就 停止 继续 查找 ， 其 返回 值 是 0 或 1。 
力 设计 过 程 
(1) 创建 PHP 脚本 。 首 先 ， 定 义 数组 变量 $a 并 为 $a 赋值 。 然 后 ， 利 用 foreach 语句 遍历 数组 以 便 取 得 key 


值 和 value 值 。 最 后 ， 利 用 正则 表达 式 函 数 preg_match0 将 通过 POST 方法 传递 进来 的 数据 进行 匹配 ， 匹 配 成 功 
则 输出 对 应 数组 的 value 值 ， 代 码 如 下 : 


<?php 
$a = array('mrsoft',' 明 日 mr 科技 ,www.mrsoft.com'); // 定 义 数组 
foreach($a as $key => $value){ //foreach 循环 遍历 数组 
$a=$_POST[te]:; 
iflpreg_match("/$al",Svalue){ /正则 表达 式 匹 配 
echo $value; 
echo "<br>"; 


8 
} 


?> 
(2) 将 该 文件 存储 于 \MR\02\110 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.84 所 示 。 
秘笈 心 ; 
心 法 领悟 110: SQL 语句 的 匹配 问题 。 
PHP 项 目 开 发 过 程 中 可 以 利用 SQL 语句 中 的 关键 字 like， 对 数据 库 中 的 内 容 进 行 匹 配 查找 ， 其 实现 的 是 数 
据 库 中 数据 的 模糊 查询 。 


实例 111 


趣味 指数 : 食 食 食 食 | 
| 


力 实例 说 明 


IP 地 址 是 互联 网 身份 的 象征 ， 通 过 IP 地 址 可 以 得 到 用 户 的 相关 信息 。 本 实例 通过 正则 表达 式 验证 IP 地 址 
是 否 合法 ， 然 后 实现 瑟 地 址 的 格式 转换 ， 进 而 获取 人 P 地 址 所 在 地 ， 运 行 结 果 如 图 2.85 所 示 。 


[En 
对 ia4548455 


2.85 利用 卫 地 址 查找 主机 所 在 地 


力 关键 技术 


首先 需要 验证 输入 的 IP 地 址 是 否 合 法 ， 如 果 合 法 ， 再 将 其 转换 为 对 应 的 数值 。 验 证 IP 地 址 是 否 合法 可 以 
通过 正则 表达 式 实现 。 

卫 地 址 使 用 4 位 地 址 定位 设备 ， 它 采用 点 分 十 进 制 数 的 格式 “xxx.xxx.xxx.xxx”， 例 如 192.168.1.66。 因 此 ， 
验证 瑟 地 址 是 否 合法 的 正则 表达 式 如 下 : 

JapGd Gd Ga/ 

将 人 P 地 址 转换 为 对 应 的 数值 可 以 应 用 以 下 公式 实现 : 


P14255+2554255+P242554255+P3+255+P441 
在 上 面 的 公式 中 ，P1 代表 人 P 地 址 第 1 段 的 数值 ，P2 代表 人 P 地址 第 2 段 的 数值 ，P3 代表 人 P 地 址 第 3 段 的 
数值 ，P4 代表 人 P 地 址 第 4 段 的 数值 。 
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图 设计 过 程 
(1) 编写 JavaScript 脚本 ， 定 义 deal0 方 法 验证 用 户 提 交 的 IP 地址 格式 是 否 正确 ， 定 义 convert0 方 法 将 全 
地 址 转换 为 对 应 数值 ， 该 方法 只 有 一 个 参数 p， 用 于 指定 了 P 地 址 ， 返 回 值 为 PP 地 址 对 应 的 数值 ， 代 码 如 下 : 


<script language="javascript"> 
function deal(myform){ // 自 定义 函数 
var ip=form] ip value: // 定 义 变量 
objExp=/(\d+).(0d+).0d+).0d+)/: /正则 表达 式 
ifip 一 ""{ // 条 件 判 断 


alert(" 请 输入 卫 地 址 !"):forml .ip focusO:retumn: 
} 
if(objExp.test(ip){ 


jelsef 
alert(" 您 输入 的 他 地 址 不 合法 !:forml.ip focusO:retum: 


ipNum.value=convert(ip); 


function convert(ip){ // 自 定义 函数 
ip=ip.split("."); 
vip=ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1; /转换 程式 
retum vip; // 返 回 值 
} 
</script> 


(2) 创建 index.php 文件 ， 通 过 form 表单 提交 要 验证 的 IP 地 址 ， 调 用 JavaScript 脚本 中 的 方法 验证 IP 地 
址 格式 并 完成 格式 的 转换 操作 。 


力 秘笈 心 法 
心 法 领悟 111: 使 用 8$_SERVER["REMOTE ADDR"] 的 注意 事项 。 
在 PHP 中 ， 可 以 通过 $_ SERVER["REMOTE_ ADDR"] 获 取 客户 机 的 卫 地 址 ， 但 并 不 能 判断 该 PP 地 址 的 所 
在 地 。 如 果 要 判断 他 地 址 的 所 在 地 ， 就 必须 对 其 格式 进行 转换 。 
寺中 文字 符 囊 截取 时 出 现 乱码 的 问题 高 级 | 
| 


趣味 指数 : 依依 依依 | 


实例 112 


力 实例 说 明 


使 用 substr0 函 数 是 按 字 节 截取 字符 串 ， 在 截取 中 文字 符 串 时 ， 由 于 一 个 汉字 由 两 个 字符 组 成 ， 如 果 只 截 
取 1 个 字符 就 会 出 现 乱 码 。 本 实例 使 用 自 定义 函数 解决 对 中 文字 符 串 截取 时 的 乱码 问题 ， 运 行 结果 如 图 2.86 
所 示 。 


吉林 省 明日 科技 帮 限 公 以 计算 轴 铭 件 捷 术 为 榨 必 型 企业 
[0 中 字 . |] 
吉林 省 明日 科技 有 有 阳 公 司 ;| + on [4 #4 


图 2.86 解决 用 substr0 函 数 对 中 文字 符 串 截取 时 的 乱码 


国 关键 技术 


对 中 文字 符 串 的 截取 虽说 是 通过 自 定义 函数 来 完成 的 ， 但 是 其 根本 还 是 应 用 substr0 函 数 ， 只 是 在 进行 字符 
串 截 取 时 ， 对 字符 串 的 类 型 进行 了 判断 。 
对 截取 字符 串 中 首 个 字 节 的 ASCII 序数 值 进行 判断 ， 如 果 ASCII 序数 值 大 于 0xa0， 则 表示 为 汉字 ， 那 么 在 
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应 用 substr0 函 数 进行 截取 时 ， 就 以 2 个 字 节 为 单位 ; 如 果 ASCII 序数 值 小 于 0xa0， 则 表示 为 英文 字符 串 ， 那 么 
在 应 用 substr0 函 数 进行 截取 时 ， 就 以 1 个 字 节 为 单位 。 这 样 将 中 文字 符 串 和 英文 字符 串 分 隔 进行 截取 就 避免 了 
出 现 乱码 的 问题 。 


自 定义 函数 msubstr0 的 语法 如 下 : 

function msubstr($str, $start, $len) { /JSstr 指 的 是 字符 串 ，Sstart 指 的 是 字符 串 的 起 始 位置 ，S$len 指 的 是 长 度 
S$strlen = $start + Slen; /用 $strlen 存储 字符 串 的 总 长 度 ( 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i = 0; $i < $strlen; $i++) { // 通 过 for 循环 语句 ， 循 环 读 取 字符 串 


于 (ord ( substr ( $str, $i, 1 ) ) > 0xa0) { ”// 如 果 字 符 串 中 首 个 字 节 的 ASCII 序数 值 大 于 0xa0， 则 表示 为 汉字 
S$tmpstr = substr ( $str, Si 2 ); /每 次 取出 两 位 字符 赋 给 变量 Stmpstr， 即 等 于 一 个 汉字 
Si++t; /变量 自 加 1 

jelse{ // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 Stmpstr 
Stmpstr .= substr ( $str, $i, 1 ); 

和 


} 
return $tmpstr; /| 输出 字符 串 


} 

其 中 ,参数 $str 是 指定 被 截取 的 字符 串 ; 参 数 $start 是 截取 的 开始 位 置 ;参数 $len 是 截取 的 长 度 。 返 回 值 Stmpstr 
是 截取 后 的 字符 串 。 

设计 过 程 

创建 index.php 文件 ， 定 义 msubstr0 函 数 ， 对 中 文字 符 串 进行 截取 。 创 建 form 表单 ， 提 交 字 符 串 截取 的 开 
始 位 置 和 长 度 ， 然 后 调用 msubstr0 函 数 对 字符 串 进行 截取 并 且 输 出 截取 结果 ， 代 码 如 下 : 


<?php 

function msubstr($str, $start, Slen) { /WSstr 指 的 是 字符 串 ，S$start 指 的 是 字符 串 的 起 始 位 置 ，$len 指 的 是 长 度 
S$strlen = $start + Slen; // 用 $strlen 存储 字符 串 的 总 长 度 〈 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i = 0; $i < $strlen; Si++) { /通过 for 循环 语句 ， 循 环 读 取 字 符 串 


让 (ord ( substr ( $str, $i, 1 ) ) > 0xa0) { /如 果 字 符 串 中 首 个 字 节 的 ASCI 序数 值 大 于 0xa0， 则 表示 为 汉字 
S$tmpstr .= substr ( $str, $i, 2 ); /每 次 取出 两 位 字符 赋 给 变量 $tmpstr， 即 等 于 一 个 汉字 
Si++ /变量 自 加 1 

j else{ /如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 Stmpstr 
Stmpstr .= substr ( $str, $i, 1 ); 

} 


} 
return $tmpstr /输出 字符 串 


} 

$string=" 吉 林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 ": 
$str=msubstr($string,$_POST[te].$_POST[tx]): 

echo $str: 

> 


图 秘笈 心 法 


心 法 领悟 112: 利用 函数 截取 中 文字 符 串 的 注意 事项 。 
使 用 substr0 函 数 截 取 中 文字 符 串 时 最 好 首先 定义 算法 ， 以 免 截 取 半 个 中 文 文字 而 出 现 乱 码 。 


实例 113 趣味 指数 : 娘娘 太太 
看 实例 说 明 


本 实例 是 通过 PHP 5.0 中 的 新 型 字符 串 实现 字符 串 与 HIML 标记 的 相互 转换 ， 运 行 结果 如 图 2.87 所 示 。 
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图 2.87 字符 串 与 HTML 标记 的 相互 转换 


图 关键 技术 
本 实例 的 关键 点 是 PHP 5.0 新 型 字符 串 的 使 用 ， 详 细 说 明 请 参见 实例 038。 


图 设计 过 程 


创建 index.php 文件 ， 利 用 PHP 5.0 新 型 字符 串 将 HTML 标记 封装 到 PHP 的 变量 中 ， 并 且 输 出 PHP 变量 的 


S$str=<<<mark // 新 型 字符 串 格式 
<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 字 符 串 与 HTML 标记 相互 转换 </title> 

</head> 


<body background="../image/1.jpe" style="font-size:16px; color:blue; font-family:' 微 软 雅 黑 "><table border="1"><tr><td> 
<form action="" method="post"> 
用 户 名 : <input type="text" name="test" size="15" /><br> 
密 &nbsp:&nbsp:&nbsp: 码 : <input type="password" name="pwd" size="15" /><br> 
<input type="submit" name="sub" value=" 提 交 " /> 
</form></td></tr></table> 
</body> 
<html> 
mark:; // 新 型 字符 串 结束 符 
S Sstr: 


| | 秘 签 心 法 


心 法 领悟 113: 新 型 字符 串 的 应 用 范围 。 
新 型 字符 串 被 广泛 应 用 在 含有 较 多 HTML 标记 的 PHP 编码 中 。 


字符 囊 输出 XML 数据 高 级 | 


力 实例 说 明 
本 实例 通过 PHP 5.0 新 型 字符 串 输出 XML 格式 的 数据 ， 运 行 结果 如 图 2.88 所 示 。 


包 运 用 PPS 新 型 字符 审 输出 TEL 数据 一 Wicroseft IAAEGEG 
EECTETOE WD 
瑞士 包 | hp//192 169.1.59/or/02/114index ph 本 加 革 到 | 三 病 可 


httpyfwrwrw mingrisoft com 吉林 省 明日 科技 有 限 公司 
httpyfwrww mingrisoft com httpyfwww mrbccdcom 明日 科技 编程 词 
典 重 者 出 击 ， 隆 重 上 市 ! 2008-08-08 


EE | | | © 人 SW 


2.88 PHP 5.0 新 型 字符 串 输出 XML 格式 的 数据 
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图 关键 技术 
本 实例 的 关键 点 是 PHP 5.0 新 型 字符 串 的 使 用 ， 详 细 说 明 请 参见 实例 038。 
图 设计 过 程 
创建 index.php 文件 ， 定 义 PHP 5.0 新 型 字符 串 ， 通 过 其 输出 XML 格式 的 数据 ， 代 码 如 下 : 


<?php 
S$str=<<<mark 
<?xml version="1.0" encoding="utf8"?> 
<rss xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:dc="http://purl.org/de/elements/1.1/" 
xmilns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0"> 
<channel> 
<title> 明 日 科技 </title> 
<link>http://www.mingrisoft.com</link> 
<description> 吉 林 省 明日 科技 有 限 公司 </description> 
<de:creator>http://www.mingrisoft.com</de:creator> 
<item> 
<title> 编 程 词典 </title> 
<link>http://www.mrbeed.com</link: 
<description> 明 站 科技 六 各 亲 典 重 闪 出 击 ， 隆重 上 市 ! </description> 
<pubDate>2008-08-08</pubDate> 
litem> 
人 


Se Se 
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心 法 领悟 114: 使 用 新 型 字符 串 的 优点 。 
在 PHP 5.0 之 前 的 开发 中 ， 想 要 在 PHP 中 输出 一 些 HTML 标记 是 通过 echo 语句 一 行 一 行 输出 的 ， 这 无 疑 
是 一 件 非常 头痛 的 事 。 现 在 PHP 提供 了 新 型 字符 串 ， 相 关 的 问题 就 可 迎刃而解 了 。 


实例 115 趣味 指数 : tool 


力 实例 说 明 


判断 一 个 字符 串 中 是 否 含有 另 一 个 字符 串 的 方法 有 很 多 ， 例 如 ， 正 则 表达 式 等 。 本 实例 通过 stristr0 函 数 判 
断 字符 串 中 是 否 存在 指定 子 串 ， 运 行 结果 如 图 2.89 所 示 。 


Hello WorldU 
归 


图 2.89 字符 串 中 不 存在 子 串 


图 关键 技术 


判断 一 个 字符 串 是 不 是 另 一 个 字符 串 的 子 串 可 通过 stristr0 函 数 实现 ， 其 语法 如 下 : 
string stristr ( string haystack, string needle ): 
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该 函数 获取 指定 字符 串 〈A) 在 另 一 个 字符 串 〈B) 中 首次 出 现 的 位 置 到 字符 串 〈B) 末尾 的 所 有 字符 串 。 
参数 haystack 指定 查找 的 字符 串 ， 参 数 needle 指定 查找 的 对 象 。 

该 函数 如 果 执 行 成 功 则 返回 剩余 的 字符 串 ， 否 则 将 返回 FALSE。 
图 设计 过 程 

创建 index.php 文件 ， 定 义 字符 串 变量 ， 将 该 变量 与 通过 POST( 方 法 传递 进来 的 数据 利用 stristr0 函 数 进行 
比较 并 输出 结果 ， 代 码 如 下 : 

<2pl 


hp 
$a = "Hello World !1"; /定义 字符 串 
echo $a; /输出 字符 串 
echo "<form action="method=-'po /输出 表单 


echo "<input type=text 人 
echo "<input type='submit name='sub' value=' 提 交 '>"; 


echo "</form>"; 
if$_POST[sub]){f /通过 POST 方式 传递 参数 
if(stristr($a, $_ POST[text]) 二 ""){ // 判 断 是 否 存在 子 串 
echo "<script>alert( 文 本 存在 指定 子 串 ):</script>"; // 提 示 
Jelse{ 
echo "<script>alert(' 文 本 不 存在 指定 子 串 );</script>"; /提示 
?> 
图 秘笈 心 ; 


心 法 领悟 115:; 知识 扩展 。 
stristrO 函 数 还 可 以 作为 分 割 函数 的 一 部 分 ， 从 符合 条 件 的 字符 串 开始 截取 ， 一 直到 文件 末尾 。 该 函数 不 区 
分 大 小 写 ， 如 果 要 在 区 分 字母 大 小 写 的 情况 下 进行 搜索 ， 可 以 应 用 strstr0 函 数 。 


2.9 正则 表达 式 


正则 表达 式 是 一 种 描述 字符 串 结构 模式 的 形式 化 表达 方法 ， 是 一 个 强大 、 便 捷 、 高 效 的 文本 处 理工 具 ， 可 
用 于 验证 用 户 输入 的 数据 和 检索 大 量 的 文本 。 在 PHP 中 , 表达 式 应 用 最 好 的 体现 是 对 表单 提交 的 数据 进行 验证 ， 
判断 是 否 合理 、 合 法 。 


力 实例 说 明 


表单 注册 时 往往 要 求 用 户 书写 座机 电话 号 码 ， 而 座机 电话 号 码 是 由 11 位 或 12 位 数字 组 成 的 ， 所 以 一 定 要 
对 电话 号 码 的 位 数 和 格式 进行 限制 .本 实例 通过 正则 表达 式 和 正则 表达 式 函 数 preg_match0) 实 现 对 电话 号 码 格式 
的 验证 ， 运 行 结果 如 图 2.90 所 示 。 


趣味 指数 : 食 食 三 食 


[aaa | 


图 2.90 验证 电话 号 码 的 格式 是 否 正确 
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图 关键 技术 


(1) preg_match0: 进行 正则 表达 式 匹配 。 
int preg_match ( string pattem, string subject [, amray matches [, int lags]]); 

(2) 正则 表达 式 ， 固定 总 位 数 为 11 位 或 12 位 的 座机 电话 。 
10d{3}-)0d{8DSI0d{4}-)0d{7 Ds/; 


力 设计 过 程 
创建 index.php 文件 ， 通 过 正则 表达 式 函数 对 输入 文本 框 的 电话 号 码 进行 验证 ， 并 输出 相关 提示 ， 其 代码 


如 下 : 
ifs_POST[sub]){ 
if(preg_match("/(\d{3}-)(d{8})$SI(d{4}-)0d{7})$/",s_POST[textD){ // 正 则 表达 式 验证 
include("ine php"); 
show_error(" 信 息 提示 "," 格 式 正确 ","index.php"); /调用 自 定义 函数 输出 提示 信息 
Jelse{ 
C include("ine php"); 
show_error(" 信 息 提示 "," 格 式 错误 ","index.php"); /调用 自 定义 函数 输出 提示 信息 
} 
} 
?> 
国 秘笈 心 法 


心 法 领悟 116: 使 用 正则 表达 式 的 注意 事项 。 
正则 表达 式 “/(\d{3}-)Qd{8))$IQNd{4}-)(\qd{7})$/” 是 根据 新 式 电话 号 码 设置 的 ， 老 式 的 座机 电话 是 由 10 位 数 


字 组 成 的 。 


实例 117 


力 实例 说 明 


互联 网 发 展 到 今天 , 几乎 所 有 的 Web 爱好 者 都 有 自己 的 E-mail 地 址 ,无 论 申请 的 是 126 邮箱 还 是 163 邮箱 ， 


E-mail 地 址 的 格式 是 固定 的 。 本 实例 通过 preg_matchO 正 则 匹配 函数 和 正则 表达 式 验证 E-mail 地 址 格式 是 否 正 


确 ， 运 行 结果 如 图 2.91 所 示 。 


2.91 ”验证 E-mail 地 址 格式 是 否 正确 


图 关键 技术 


(1) preg_matchO 函 数 : 进行 正则 表达 式 匹 配 ， 详 细 参 数 参 见 实例 110。 


(2) 了 


E 则 表达 式 : 对 E-mail 地 址 进行 验证 。 


Nr(E Tt @ rt J (Jt): 
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// 包 含 信息 提示 页 


趣味 指数 : 请 请 请 育 | 
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力 设计 过 程 
创建 index.php 文件 ， 当 单 击 “ 验 证 ”按钮 时 ,通过 正则 表达 式 函 数 验证 文本 框 传 入 的 信息 并 输出 对 应 提示 ， 
其 代码 如 下 : 
if(s_ POST[subD){ 
require_once("inc.php"); // 包 含 信息 提示 页 
if(preg_match("/N\w+([-+,] w+)*@\wt([- J wr) * wt([-. J )*/",trim($_POST[ text D){ // 正 则 表达 式 验证 
show_error(" 信 息 提示 "," 格 式 正确 ","index.php"); /输出 提示 
Jelse{ 
show_error(" 信 息 提示 "," 格 式 不 正确 "."index.php"); /输出 提示 
} 
a 
?> 
秘笈 心 法 


心 法 领悟 117: PHP 支持 的 两 种 正则 表达 式 函 数 库 。 
PHP 支持 两 种 正则 表达 式 函 数 库 ， 一 种 是 正则 表达 式 函 数 库 (POSIX 扩展 ) ， 另 外 一 种 是 正则 表达 式 函 数 
库 (Perl 兼容 ) 。 在 性 能 上 ，Perl 兼容 正则 表达 式 速度 更 快 一 些 。 


高 级 | 
起 味 指数 : 请 塘 庚 庚 


实例 118 


图 实例 说 明 


IP 地 址 是 Web 用 户 可 以 访问 互联 网 的 身份 凭证 。 每 一 个 IP 地 址 相对 其 他 用 户 的 他 都 是 独立 的 。 本 实例 通 
过 正则 表达 式 函 数 preg_match0 和 正则 表达 式 对 IP 地 址 进行 验证 ， 运 行 结果 如 图 2.92 所 示 。 


2.92 ”验证 人 P 地 址 是 否 有 效 


图 关键 技术 


(1) preg_match_ all0 函 数 ， 在 字符 串 subject 中 匹配 表达 式 pattem， 函 数 返 回 匹 配 的 次 数 。 如 果 有 数组 
matches， 那 么 每 次 匹配 的 结果 将 被 存储 到 数组 matches 中 ， 其 语法 如 下 : 


int preg_match_all ( string pattem, string subject [, array matches] ) 
(2) 正则 表达 式 : 对 人 P 地 址 进行 验证 。 


"Ndr\dt\dr\\d+/":; 


图 设计 过 程 


(1) 创建 index.php 文件 ， 通 过 form 表单 提交 IP 地 址 ， 当 单 击 “ 验 证 ”按钮 时 ， 通 过 正则 表达 式 函 数 验 
证 焉 地址 ， 并 且 返 回 验证 结果 ， 其 代码 如 下 : 


<2php 
if($_POST['subD){ 
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Tequire_once("inc.php"); 
if(preg_match("/N\d+\\d+\\d+\\d+/",trim($_POST['text])){ 
show_error(" 信 息 提示 "." 格 式 正确 ","index.php"); 
yelse{ 
show_error(" 信 息 提 示 "," 格 式 不 正确 ","index.php"); 
} 
} 


(02) 创建 inc.php 文件 ， 定 义 方法 show_error0， 根 据 传递 的 参数 值 定义 返回 的 错误 信息 。 
国 秘笈 心 法 
心 法 领悟 118: IP 地 址 是 什么 。 
Internet 为 每 一 个 主机 分 配 唯一 的 一 个 32 位 地 址 ， 该 地 址 称 为 IP 地 址 ， 也 称 网 际 地 址 。JP 地 址 由 4 个 数组 


成 ， 每 个 数 取 值 范围 为 0-255， 每 两 个 数 之 间 用 “.” 分 隔 。 所 以 IP 地 址 的 格式 是 固定 的 ， 正 则 表达 式 
“Ad+\d+\dt\.\d+/” 可 以 验证 所 有 IP 地 址 。 


趣味 指数 : Po 


实例 119 


实例 说 明 


统计 关键 字 的 查询 结果 的 方法 有 很 多 ， 本 实例 通过 正则 表达 式 函 数 split0 和 count0 实 现 统计 关键 字 ， 运 行 
结果 如 图 2.93 所 示 。 


PHP 作 为 全 球 最 普及 、 应 用 最 | 
知名 互联 网 公司 Google、Yal 
输出 关键 字 P- 志 

of /34 4 BA MN 3 +41 


图 2.93 ”统计 关键 字 的 查询 结果 


图 关键 技术 


splitO 函 数 : 用 正则 表达 式 将 字符 串 分 割 到 数组 中 。 

array split ( string pattern, string string [, int limit]); 

该 函数 返回 一 个 字符 串 数 组 ， 每 个 单元 为 string 经 区 分 大 小 写 的 正则 表达 式 pattern 作为 边界 分 割 出 的 子 
串 。 如 果 设 定 了 limit， 则 返回 的 数组 最 多 包含 limit 个 单元 ， 而 其 中 最 后 一 个 单元 包含 string 中 剩余 的 所 有 部 
分 。 如 果 出 错 ， 则 split0 函 数 返 回 FALSE。 


力 设计 过 程 
创建 index.php 文件 。 首 先 ， 定 义 字 符 串 变 量 $str 并 为 $str 赋值 。 然 后 ， 利 用 split0 函 数 检索 字符 p 在 $str 中 
的 出 现 次 数 ， 并 输出 检索 的 结果 ， 其 代码 如 下 : 


<2php 
/定义 字符 串 变量 
$str = "PHP 作为 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 ， 从 1994 年 诞生 至 今 已 被 2000 多 万 个 动态 网 站 采用 ， 全 球 知 名 互联 网 公司 
Google、Yahoo、eBay 和 中 国 知名 网 站 新 浪 、 百 度 、 阿 里 巴巴 等 均 采 用 PHP 技术 ! "; 
S$b = split("P",Sstr): /使 用 split0 函 数 进行 分 割 
echo "<h4 style =red>"; 
echo $str."<br>"; 
echo "</h4>"; 


150 


第 2 章 PHP 基础 


echo "输出 关键 字 P 一 共 出 现 ".(count($b)-1)." 次 "; // 利 用 count0 函 数 进 行 统计 
> 


国 秘笈 心 法 


心 法 领悟 119: split0 函 数 的 实现 原理 。 
splitO 正 则 表达 式 函数 是 将 字符 串 分 割 到 数组 中 , 如 果 字 符 串 中 有 n 个 与 pattern 匹配 的 项 目 , 则 返回 的 数 
组 将 包含 n+l 个 单元 ， 所 以 count0 在 计算 时 要 减 1。 


实例 120 


力 实例 说 明 


计算 机 的 每 一 步 操作 都 是 需要 时 间 的 ， 只 不 过 由 于 时 间 过 于 短暂 ， 用 户 感 觉 不 到 。 本 实例 通过 时 间 惟 函数 
microtime0O 计 算 查 询 操作 的 执行 时 间 ， 运 行 结果 如 图 2.94 所 示 。 


id:1 
查询 操作 所 用 时 间 为 ， aooaoseb 


图 2.94 计算 查询 操作 的 执行 时 间 


图 关键 技术 


获取 查询 操作 的 执行 时 间 ， 在 PHP 中 主要 是 使 用 microtime0 函 数 实 现 ， 其 语法 如 下 : 


mixed microtime ( [bool get_as_float] ); 


该 函数 获取 某 一 时 刻 的 时 间 戳 的 微 秒 数 。 
力 设计 过 程 
创建 index.php 文件 。 首 先 ， 连 接 数据 库 并 设置 页 面 的 编码 风格 ， 在 执行 查询 操作 的 开始 与 结束 的 两 个 时 间 


点 定义 两 个 变量 ， 分 别 利用 microtime0O 函 数 获取 两 点 时 间 戳 的 微 秒 数 。 然 后 计算 两 个 时 间 戳 的 差 值 ， 取 得 程序 
的 执行 时 间 ， 其 代码 如 下 : 


<?php 
Sconn = mysql_connect("localhost","root","111")or die(" 连 接 mysql 出 现 错误 "); // 连 接 MySQL 
mysql_select_db("db_database02",$conn): // 连 接 数 据 库 
$sql = "SELECT * FROM tb_select"; JSQL 语句 
$a = microtime(); // 取 得 当前 时 间 截 的 微 秒 数 
Srs = mysql_query($sql); // 查 询 操作 


while($rst = mysql_fetch_array($rs)) 
echo "id:".$rst[O]."<br>"; 
/取得 当前 时 间 戳 的 微 秒 数 


$b = microtime0: 
echo "查询 操作 所 用 时 间 为 : "(Sb-$aj." 秒 ": /输出 结果 
> 


[ED 说 明 : 本 实例 所 用 的 数据 表 没 有 足够 多 的 数据 ， 以 至 于 执行 速度 太 快 几乎 不 需要 时 间 ， 为 了 显示 结果 ， 笔 
者 人 为 让 程序 休 具 1 秒 钟 。 


国 秘笈 心 ; 
心 法 领悟 120: 知识 扩展 。 
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time0 和 mktime(O) 函 数 在 不 指定 参数 的 情况 下 具有 相同 的 作用 ， 都 是 返回 自从 UNIX 新 纪元 (格林 威 治 时间 
1970 年 1 月 1 日 00:00:00) 到 当前 时 间 的 秒 数 ， 而 microtime0) 函 数 只 是 单纯 取得 两 个 时 间 戳 的 微 秒 数 。 


高 级 | 


实例 121 趣味 指数 : 娘娘 妇女 


力 实例 说 明 


关键 字 描 红 技术 在 实例 088 中 已经 进行 过 讲解 ， 本 实例 是 通过 正则 表达 式 蔡 换 函数 preg_replace0 实 现 查询 
关键 字 描 红 ， 运 行 结果 如 图 2.95 所 示 。 


2.95 查询 关键 字 描 红 


图 关键 技术 
执行 蔡 换 或 关键 字 描 红 时 经 常 使 用 PHP 预定 义 函数 preg_replace0， 其 语法 如 下 : 


mixed preg replace ( mixed pattern, mixed replacement, mixed subjeet [, int limit] ); 
参数 说 明 : 

mixed pattem: 规定 替换 规则 。 

mixed replacement: 替换 部 分 。 

mixed subject: 蔡 换 内 容 的 源 信息 。 

主要 功能 : 执行 正则 表达 式 的 搜索 和 蔡 换 。 


图 设计 过 程 

创建 index.php 文件 。 首 先 连接 数据 库 并 设置 页 面 的 编码 风格 ， 当 单 击 “ 搜 索 ” 按 钮 时 ， 执 行 查询 操作 并 将 
文本 框 输入 的 信息 进行 描 红 处 理 ， 最 后 利用 正则 表达 式 函 数 preg_replace0 蔡 换 数据 信息 ， 其 代码 如 下 : 

<Ipbp 


$conn = mysql_connect("localhost","root","111")or die(" 连 接 mysql 出 现 错误 "); /连接 MySQL 

mysql_select_db("db_database02".$conn): /连接 数据 库 

mysql_query("SET NAMES GBK"): // 设 置 编码 格式 

if($_POST[sub){ // 通 过 POST 方式 传递 参数 
JSQL 语句 


$sql = "select * from tb_sel where tb_sel.name like (9%S_POST[text]%) or tb_sel.add like (9%S_POST[text]9%o) or tb_sel.sex like 
(%$_POST[text]%") or tb_sel.QQ like(%$_POST[text]%6)": 


$a=$ POST[text]: // 原 参数 
$b = "<b><font color=#FF0000>".$_POST[text]."</font></b>"; // 描 红 后 的 参数 
> 
<table border="1" bordercolor="#0033CC" cellspacing="0"><tr><td> 用 户 名 </td><td> 性 别 </td><td> 住 址 </td><td>QQ</td></tr> 
<?php 
while($rst = mysql fetch_array(Srs)){ /查询 输出 
Srste = preg_replace("/$a/",$b,Srst); /正则 著 换 
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/输出 表格 
echo "<tr><td>" Srste[name]."</td><td>" S$rste[sex]."</td><td>" Srste[add]."</td><td>". Srste[QQ]."</td></tr><br>"; 


} 
> 
</table> 
心 法 领悟 121: 使 用 preg_replace0 函 数 的 相关 说 明 。 


preg_replace0 函 数 的 每 个 参数 (除了 limit) 都 可 以 是 一 个 数组 。 如 果 pattern 和 replacement 都 是 数组 ， 
将 以 其 键 名 在 数组 中 出 现 的 顺序 来 进行 处 理 。 


高 级 | 
* | 


实例 122 趣味 指数 : 依依 依依 


力 实例 说 明 


前 面 的 实例 中 已 经 介绍 了 对 文件 类 型 的 相关 操作 , 本 实例 采用 正则 表达 式 函 数 preg_matchO 实 现 判断 上 传 文 
件 的 类 型 ， 运 行 结果 如 图 2.96 所 示 。 


F:\xampp\xampp\lice 
上 传 为 图 片 类 型 
图 2.96 判断 上 传 文件 的 类 型 


力 关键 技术 

使 用 preg_match0 函 数 进行 正则 表达 式 匹配 ， 详 细 说 明 参见 实例 110。 
图 设计 过 程 

创建 index php 文件 ， 当 单 击 “ 上 传 ”按钮 时 ， 利 用 preg_matchO 正 则 表达 式 函 数 将 上 传 的 数据 信息 进行 匹 
配 并 输出 结果 ， 其 代码 如 下 ， 


if($_POST[sub){ // 让 条 件 语句 
if(preg_match("/jpg/".strtolower($_POST[text)){ // 通 过 正则 表达 式 函 数 判 断 类 型 
echo "上 传 为 图 片 类 型 "; 
yelse{ 
iflpreg_match("/.rar/",: tt POST[text)) { 
echo "上 传 为 压缩 包 类 型 
jelsef 
echo "其 他 文件 类 型 "; 
} 
} 


} 
?> 


力 秘笈 心 ; 


心 法 领悟 122: 知识 扩展 。 
本 实例 使 用 的 是 ff...else.…. 语 句 榜 套 从 结构 上 看 不 是 很 明朗 ,读者 可 以 运用 switch 语句 改写 此 实例 ， 相 信 
在 系统 运行 效率 上 会 有 所 提高 。 
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实例 123 


力 实例 说 明 


用 户 在 购买 电子 商务 网 站 的 商品 时 ， 商 品 一 般 都 是 以 快递 或 邮寄 的 方式 传递 到 用 户 手 中 ， 所 以 如 果 用 户 不 
能 正确 地 填写 邮寄 地 址 或 邮政 编码 , 就 有 可 能 造成 不 必要 的 损失 。 本 实例 通过 正则 表达 式 函 数 preg_match0 验 证 
用 户 提交 的 邮政 编码 格式 是 否 正确 ， 运 行 结果 如 图 2.97 所 示 。 


图 2.97 验证 邮政 编码 是 否 有 效 


图 关键 技术 


(1) preg_match0 函 数 ， 进行 正则 表达 式 匹 配 ， 详 细 参 数 参见 实例 110。 
(2) 正则 表达 式 ， 对 邮政 编码 格式 进行 验证 。 
"0-9]{6}"; 
图 设计 过 程 
创建 index.php 文件 ， 当 单 击 “ 验 证 ”按钮 时 ， 利 用 preg_match0 正 则 表达 式 函 数 对 文本 框 的 输入 信息 进行 
匹配 并 输出 提示 ， 其 代码 如 下 : 
局 


php 
这 S$_POST[sub]){ // 通 过 POST 方式 传递 参数 
require_once("inc.php"); // 包 含 文件 
if(preg_match("/[0-9]{6}/",trim($_POST['text])){ // 正 则 表达 式 


show_error(" 信 息 提示 "," 格 式 正确 ","index.php"); 。“// 显 示 信息 
jelsef 
show_error(" 信 息 提示 "" 格 式 不 正确 "…"index.php"): 


} 


> 


国 秘笈 心 法 
心 法 领悟 123: 什么 是 邮政 编码 。 
邮政 编码 是 为 了 实现 邮政 分 拣 自 动 化 和 邮政 网 络 数字 化 设置 的 ， 以 加 快 邮件 邮递 速度 。 目 前 世界 上 有 40 多 


个 国家 先后 实行 了 邮政 编码 制度 ， 并 以 此 作为 衡量 一 个 国家 通信 技术 和 邮政 服务 水 平 的 标准 之 一 。 各 国 邮 政 编 
码 规则 并 不 统一 。 


2.10 数 组 
数组 是 对 大 量 数据 进行 组 织 和 管理 的 有 效 手 段 之 一 ， 通 过 数组 的 强大 功能 ， 可 以 对 大 量 性 质 相同 的 数据 进 
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行 存储 、 排 序 、 插 入 及 删除 等 操作 ， 从 而 可 以 有 效 地 提高 程序 开发 效率 及 改善 程序 的 编写 方式 。 
实例 
力 实例 说 明 


如 果 只 是 想 保 存 几 个 数据 就 没有 必要 和 数据 库 交互 ， 此 时 可 以 选用 数组 。 本 实例 通过 数组 函数 array0 实 现 
创建 并 输出 数组 ， 运 行 结果 如 图 2.98 所 示 。 


| 书写 字符 率 以 # 号 分 割 创建 数组 ] [ 输出 数组 
Array ( [0).=»123 [2] 之 789) 


图 2.98 输出 数组 


图 关键 技术 
array(); 新 建 一 个 数组 。 


array array ( [mixed …] ); 

参数 mixed 的 语法 为 “key=>value”， 多 个 mixed 参数 之 间 用 逗号 隔 开 ， 分 别 定义 了 索引 和 值 。 索 引 可 以 
是 字符 串 或 数字 。 如 果 省 略 了 索引 将 是 目前 最 大 的 整数 索引 +1。 如 果 定 义 了 两 个 完全 一 样 的 索引 ， 则 后 面 一 个 
会 覆盖 前 一 个 。 数 组 中 的 各 数据 元 素 的 数据 类 型 可 以 不 同 ， 也 可 以 是 数组 类 型 。 当 mixed 是 数组 类 型 时 ， 该 数 
组 就 是 二 维 数组 。 


力 设计 过 程 
创建 index.php 文件 ， 当 单 击 “ 创 建 数组 ”按钮 时 ,首先 ,判断 文本 框 信息 是 否 为 空 ， 如 果 为 空 则 输出 提示 ， 


否则 将 文本 框 信息 保存 在 SESSION 变量 中 ; 当 单 击 “ 输 出 数组 ”按钮 时 ， 首先， 判断 网 页 中 是 否 存在 SESSION 
变量 ， 如 果 存 在 变量 则 利用 字符 串 拆 分 函数 进行 拆 分 并 打印 输出 ， 其 代码 如 下 : 


php 
if($_POST[sub1){ // 通 过 POST 方式 传递 参数 
if($_POST[text] = ""){ // 如 果 文本 框 为 空 
echo "<script>alert( 您 创建 了 一 个 空 数 组 ):location href="index.php'</script>"; /输出 提示 
jelsef 
S$_SESSION[array] = $_POST[text]: // 将 结果 保存 在 SESSION 中 
echo "<script>alert( 创建 数组 成 功 ):location href='index.php'</script>"; /| 提示 
} 
} 
if($_POST[sub2){ /通过 POST 方式 传递 参数 
iflisset($_SESSION['aray]){ // 如 果 SESSION 存在 
Sarray = explode("#".$_SESSION['aray"]): /分割 字 符 串 
Print_r($array): /打印 
session_destroy(): 1/ 销毁 SESSION 
jelsef 
echo "<seript>alert(' 请 先 创建 数组 ):location hre 人 index.php'</script>": /提示 
} 
) 
2> 
力 秘笈 心 法 


心 法 领悟 124: 数组 的 重要 作用 。 


数组 是 PHP 基础 语言 中 很 重要 的 一 部 分 ， 灵 活 运用 数组 会 起 到 事半功倍 的 效果 。 
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i 
实例 125 | ao 


力 实例 说 明 


数组 下 标 默认 是 以 0 为 开始 键 值 的 整 型 数据 ， 如 果 想 取得 数组 元 素 的 个 数 就 要 使 用 count0 函 数 。 本 实例 通 
过 count0 函 数 统计 数组 元 素 个 数 ， 运 行 结果 如 图 2.99 所 示 。 


图 2.99 统计 数组 元 素 个 数 


图 关键 技术 
在 PHP 中 ， 应 用 count0 函 数 对 数组 中 的 元 素 个 数 进行 统计 ， 其 语法 如 下 : 


int count ( mixed array [, int mode]) 

参数 说 明 : 

array: 必 选 参数 ， 指 定 被 统计 的 数组 。 

mode: 可 选 参数 ， 其 参数 值 为 COUNT_RECURSIVE (或 1) ， 如 选中 此 参数 ， 本 函数 将 递归 地 对 数组 计 
数 。 对 计算 多 维 数 组 的 所 有 单元 尤其 有 用 。 此 参数 的 默认 值 是 0。 
图 设计 过 程 

创建 index.php 文件 ,首先 定义 数组 变量 并 为 此 变量 赋值 ,然后 利用 count0 函 数 输出 数组 元 素 的 个 数 ， 其 代 
码 如 下 : 


<?php 

$a = array(1', 精 细 ',asd',asd123"); /声明 数组 

echo "数组 中 存在 元 素 ".count($a)." 个 "; 1/ 计 算数 组 元 素 个 数 
?> 


国 秘笈 心 法 
心 法 领悟 125， 使 用 count0 函 数 的 注意 事项 。 


如 果 count0 函 数 的 操作 对 象 是 NULL， 那 么 返回 结果 为 0。count0 函 数 对 没有 初始 化 的 变量 返回 0， 但 对 于 空 
的 数组 也 会 返回 0。 如果 要 判断 变量 是 否 初始 化 ， 则 可 以 应 用 isset0 函 数 。 另 外 ，countO 函 数 不 能 识别 无 限 递归 。 


2 
实 伯 
看 实例 说 明 
数组 元 素 的 个 数 和 元 素 值 是 可 以 改变 的 。 本 实例 通过 数组 函数 array_push0 向 数组 中 添加 元 素 ， 运 行 结果 如 


图 2.100 所 示 。 
| 厦 数 组 : Array (I0] = > 少 细 加 = >asdB = 
添加 元 素 后 的 数组 >: -> 四 => 精细 [2 - 一 > asd123 [名 二 分 
6 哈 ) 


2.100 ”向 数组 中 添加 元 素 
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国 关键 技术 
在 PHP 中 ， 向 数组 中 添加 元 素 使 用 arny_push0 本 数 ， 其 语法 如 下 ; 


int armray_ push ( array array. mixed var [, mixed 

参数 说 明 : 

array array: 原 数组 。 

mixed var: 压 入 的 数据 元 素 。 

该 函数 将 array 当成 一 个 栈 ， 并 将 传 入 的 变量 压 入 array 的 末尾 。 


图 设计 过 程 
创建 index php 文件 ， 首 先 ， 定 义 数组 变量 ， 并 为 数组 变量 赋值 。 然 后 ， 利 用 amray_ push0 函 数 向 数组 中 添 
加 元 素 并 打印 数组 输出 信息 ， 其 代码 如 下 : 


<php 
$a = array(1', 精 细 ''asd',asd123"); /声明 一 个 数组 
echo " 原 数 组 : 
print_r($a)."<br>"; /输出 数组 
array_push($a,' 了 哈哈"); // 向 数组 末尾 添加 元 素 
echo "<br> 添 加 元 素 后 的 数组 :"; 
print_r($a); /打印 添加 元 素 后 的 数组 

?> 

国 秘笈 心 ; 


心 法 领悟 126: 使 用 array_push0 函 数 的 相关 说 明 。 
如 果 用 array_push0 函 数 单纯 地 给 数组 增加 一 个 单元 ， 不 如 选用 “$array[]=”， 因 为 这 样 没有 调用 函数 的 
额外 负担 。 


力 实例 说 明 


创建 数组 时 ， 由 于 朴 忽 将 元 素 内 容 书写 错误 ， 更 改 错误 的 元 素 内容 可 以 通过 数组 键 值 实现 。 本 实例 通过 数 
组 下 标 〈 键 值 ) 实现 将 数组 中 指定 索引 位 置 的 元 素 赫 换 ， 运 行 结果 如 图 2.101 所 示 。 


A 中 => 精细 [2] =>asd [ 123 ) 
指定 索引 元 ay ( [ol => 工 加 二 > > 经 济 团 => 
关公 

的 元 素 发 生 更 改 


图 2.101 将 数组 中 指定 索引 位 置 的 元 素 普 换 


| bodedododl 


力 关键 技术 


PHP 数字 索引 由 数字 组 成 ， 下 标 从 0 开始 ， 数 值 索引 一 般 表 示 数 组 元 素 在 数组 中 的 位 置 ， 数 字 索 引 数组 默 
认 索 引 值 从 数字 0 开始 ， 不 需要 特别 的 指定 ，PHP 会 自动 为 索引 数组 的 键 名 赋 一 个 整数 值 ， 然 后 从 这 个 值 开始 
自动 增 量 ， 当 然 也 可 以 指定 某 个 位 置 开 始 保存 数据 。 


图 设计 过 程 
创建 ndex php 文件 ， 定 义 数组 变量 并 通过 数组 下 标 输出 元 素 ， 其 代码 如 下 : 
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echo " 原 数组 元 素 :"; 
$a = array(1',' 精 细 ','asd''asd123); // 定 义 数组 
print_r($a); // 打 印 数组 
echo "<br> 指 定 索引 元 素 蔡 换 后 的 数组 : "; 
SaD] = 经济; // 根 据 数组 下 标 更 改元 素 
print_r($a); // 打 印 更 改 后 的 数组 
echo "<br> 键 值 2 的 元 素 发 生 更 改 "; 
> 
二 
力 秘笈 心 法 


心 法 领悟 127: 使 用 数组 键 值 的 注意 事项 。 
当 使 用 “组 名 称 [ 键 值 ]” 这 样 的 格式 时 ， 要 注意 数组 键 值 是 从 0 开始 的 ， 所 以 本 例 中 更 改 键 值 为 2 的 元 素 ， 
其 实 是 数组 中 的 第 3 个 元 素 。 


实例 128 趣味 指数 : 走 丰 页 本 | 


力 实例 说 明 
在 数组 元 素 比较 多 的 情况 下 , 想 要 取得 数组 中 的 最 后 一 个 元 素 可 以 通过 5 
获取 数组 中 最 后 - 


先 计算 元 素 的 个 数 再 通过 下 标 取得 ,还 可 以 通过 函数 取得 。 本 实例 通过 数组 
函数 aray_ pop0 实 现 获取 数组 中 的 最 后 一 个 元 素 ,运行 结果 如 图 2.102 所 示 。 图 2 10》 获取 数组 中 最 后 一 个 元 素 


图 关键 技术 
使 用 array pop0 函 数 获取 并 返回 array 数组 的 最 后 一 个 单元 ， 并 将 数组 array 的 长 度 减 1， 其 语法 如 下 : 


mixed array_pop ( array array); 
图 设计 过 程 

创建 index.php 文件 。 首先 定义 数组 变量 $a 并 为 此 数组 变量 赋值 ， 然 后 利用 函数 array_pop0 弹 出 数组 中 的 最 
后 一 个 元 素 并 输出 结果 ， 其 代码 如 下 : 


Iphp 


$a = array('a','b',. hi; // 声 明 数组 
echo "获取 数组 中 最 后 一 个 元 素 是 : "array_pop(Sa): /返回 数组 中 最 后 一 个 元 素 
> 
力 秘笈 心 法 


心 法 领悟 128: 使 用 array_pop0 函 数 的 相关 说 明 。 

在 使 用 array_popO 函 数 时 ， 数 组 中 最 后 一 个 元 素 是 被 取出 而 不 是 被 复制 ， 即 每 次 使 用 此 函数 ， 数 组 元 素 就 
会 减少 一 个 。 如 果 数 组 为 空 〈 或 者 不 是 数组 ) 将 返回 NULL。 
高 级 | 


实例 129 趣味 指数 : fi 


力 实例 说 明 
在 数组 中 键 值 是 唯一 的 ， 但 是 元 素 的 值 是 可 以 重复 的 。 想 要 删除 数组 元 素 中 重复 的 值 可 以 使 用 函数 


158 


第 2 章 PHP 基础 
array uniqueO0。 本 实例 是 通过 数组 函数 array_unique0 去 除数 组 中 的 重复 元 素 值 ， 运 行 结果 如 图 2.103 所 示 。 


a [=>b[2>aBl =>a[9 => ffgl 
上 “各 De 
(=>a [Y=>5 Bl =>f0=> hy 


司 2.103 ”去 除数 组 中 的 重复 元 素 


力 关键 技术 
在 PHP 中 ， 通 过 array unique0 函 数 去 除数 组 中 的 重复 元 素 ， 其 语法 如 下 : 


array array_unique ( array array); 
参数 array 为 指定 参数 的 数组 ， 其 返回 值 为 一 个 没有 重复 元 素 的 新 数组 。 
图 设计 过 程 
创建 index.php 文件 。 首 先 创建 数组 变量 $a 并 为 其 赋值 ， 然 后 利用 array_unique0) 函 数 去 除数 组 中 的 重复 元 
素 值 ， 最 后 打印 数组 ， 其 代码 如 下 : 
有 $a = amray(avbvavdvavfuavbhva; /定义 数组 
echo " 原 数 组 元 素 为 :"; 
Print_r($a); // 打 印 数 组 
echo "<br> 去 除 重复 项 后 的 数组 为 :"; 


Print_r(array_unique($a)); // 输 出 去 除 重复 项 的 数组 
> 


国 秘笈 心 ; 
心 法 领悟 129: 使 用 array_uniqueO 函 数 的 原理 。 


使 用 array_uniqueO 函 数 的 原理 是 先 将 值 作为 字符 串 排序 ， 然 后 对 每 个 值 只 保留 第 一 个 遇 到 的 键 名 ， 而 忽略 
所 有 后 面 的 键 名 。 但 这 并 不 意味 着 在 未 排序 的 数组 中 同一 个 值 的 第 一 个 出 现 的 键 名 会 被 保留 。 


; a a 
图 实例 说 明 


实例 109 介绍 了 字符 串 与 数字 之 间 的 转换 ， 下 面 来 介绍 字符 串 与 数组 之 间 的 转换 。 本 实例 通过 强制 类 型 转 
换 实现 字符 串 与 数组 的 转换 ， 运 行 结 果 如 图 2.104 所 示 。 


计时 转 抽 为 数组 DE 
Hat 


图 2.104 字符 串 与 数组 的 转换 


图 关键 技术 


虽然 PHP 是 弱 类 型 语言 , 但 有 时 仍然 需要 用 到 类 型 转换 。PHP 中 的 类 型 转换 和 C 语言 一 样 ， 非 常 简单 ， 在 
变量 前 加 上 用 括号 括 起 来 的 类 型 名 称 即 可 。 人 允许 转换 的 类 型 如 表 2.7 所 示 。 
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表 2.7 类 型 强制 转换 


转换 操作 符 转换 类 型 举例 
(boolean) 转换 成 布尔 型 (boolean)$num、(boolean)$str 
(string) 转换 成 字符 型 (string)$boo、(string)$flo 
(integer) 转换 成 整 型 (integer)$boo、(integer)$str 
(float) 转换 成 浮 点 型 (floa)$str、(float)$str 

(array) 转换 成 数组 (array)$str 


转换 成 对 象 


objecb$str 
力 设计 过 程 

创建 index.php 文件 。 首 先 定义 数组 变量 并 为 此 变量 赋值 ， 然 后 利用 强制 类 型 转换 的 方法 将 字符 串 类 型 转换 
为 数组 类 型 ， 其 代码 如 下 : 

<?pl 


hp 
$a="123"; // 声 明 字符 串 变量 
Sb = (array)$a: // 将 字符 串 转换 为 数组 
echo "字符 串 转换 为 数组 : "; 
Print_r($b); /打印 数组 
echo "<hr>"; 
Sc =array('1); // 定 义 数 组 
$d = (string)$e; // 将 数组 转换 为 字符 串 
echo"<br> 数 组 转换 为 字符 串 : ": 
echo $d; /输出 字符 串 
> 
> i 
力 秘笈 心 法 


心 法 领悟 130: 将 数组 强制 转换 成 字符 串 的 注意 事项 。 
将 数组 强制 转换 成 字符 串 时 ， 数 组 将 被 转换 成 字符 串 "Array"， 因 此 无 法 通过 echo0 或 者 printO 函 数 来 输出 
数组 的 内 容 。 


实例 131 


国 实例 说 明 
本 实例 通过 shuflle0 函 数 实现 对 数组 元 素 进行 随机 排序 ， 运 行 结果 如 图 2.105 所 示 。 


原 数组 元 素 顺 序 为 : 23 asd 
经 随机 排序 后 - 习 和 b 


2.105 ”对 数组 元 素 进行 随机 排序 


力 关键 技术 
在 PHP 中， 将 数组 元 素 进行 随机 排序 使 用 shuffle0 函 数 ， 其 语法 如 下 : 
使 用 该 数 将 数组 打 总 ， 随 机 排序 。 
图 设计 过 程 
新 建 index.php 文件 。 首 先 定义 数组 变量 ， 利 用 srand0 函 数据 下 随机 数 发 生 器 种 子 ， 然 后 利用 shufle0 函 数 


160 


第 2 章 PHP 基础 


将 数组 打 乱 ， 最 后 输出 数组 元 素 ， 其 代码 如 下 : 
<Iphp 
Snumbers = amay( 经 济 vavb:"123"vasd; 
echo " 原 数组 元 素 顺序 为 : 经 济 ab 123 asd"; 
srand ((float)microtime()*1000000): 
shuffle (Snumbers): 
echo "<br> 经 随机 排序 后 : "; 
while (list (, Snumber) = each ($numbers)) { 
echo "$number ": 
} 


?> 


心 法 领悟 131: 使 用 shuffle0) 函 数 的 注意 事项 。 
在 使 用 shuffle0 函 数 将 数组 打 乱 时 ， 必 须 用 srand0 函 数 播 下 本 函数 的 随机 数 发 生 器 的 种 子 ， 否 则 得 不 到 预 
期 结果 。 


图 实例 说 明 

可 以 把 随机 抽取 数组 中 的 元 素 看 成 一 个 彩票 抽奖 的 大 摇 箱 ， 在 原理 上 两 者 是 没什么 区 别 的 ， 但 是 彩票 抽奖 
的 大 摇 箱 可 能 存在 一 点 点 的 偶然 性 ， 例 如 大 摇 箱 里 的 球 弹力 不 同等 。 本 实例 通过 随机 函数 rand0 实 现 随机 抽取 
数组 中 的 元 素 ， 运 行 结果 如 图 2.106 所 示 。 


rm, EN 
随机 取得 数组 的 元 素 是 


2.106 ”随机 抽取 数组 中 元 素 


ea 


高 级 


| 
趣味 指数 : 傅 傅 痕 良 | 


力 关键 技术 


应 用 rand0 函 数 获取 随机 数值 ， 并 将 随机 数值 指向 数组 下 标 从 而 实现 随机 获取 指定 元 素 的 值 。rand0 函 数 的 
语法 如 下 : 

int rand ( [int min, int max]): 

参数 说 明 : 

min: 随机 数 的 最 小 值 。 

max: 随机 数 的 最 大 值 。 


力 设计 过 程 

创建 PHP 脚本 。 首 先 定义 数组 变量 并 为 数组 变量 赋值 ， 然 后 利用 rand0 函 数 获取 0~4 中 的 一 个 随机 数 ， 并 
将 此 随机 数 赋 给 数组 变量 作为 数组 变量 的 键 值 ， 最 后 输出 此 数组 变量 ， 其 代码 如 下 : 

<2php 


$numbers = array(' 经 济 ",'a','b'"123',asd"); /定义 数组 

echo "数组 :"; 

print_r(Snumbers): 

Srand = rand(0.4): /创建 一 个 0~4 的 随机 数字 


echo "<br> 随 机 取得 数组 的 元 素 是 : ".Snumbers[Srand]: 。“// 将 随机 数字 作为 键 值 获取 数组 元 素 
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力 秘笈 心 法 


心 法 领悟 132: 随机 函数 rand0 的 相关 说 明 。 
在 使 用 随机 函数 rand0 时 ， 如 果 没 有 提供 可 选 参数 min 和 max， 该 函数 返回 0-RAND_MAX 之 间 的 伪 随 
机 数 。 例 如 ， 想 得 到 10~30 (包括 10 和 30) 之 间 的 随机 数 ， 使 用 rand(5, 15)。 


F NA i 
图 实例 说 明 


二 维 数组 可 以 简单 理解 为 数组 元 素 中 还 包含 一 个 数组 。MySQL 图 形 化 管理 工具 phpMyAdmin 中 存储 的 每 
个 数据 表 其 实 就 是 一 个 二 维 数组 。 本 实例 实现 二 维 数组 中 数据 的 输出 ， 运 行 结果 如 图 2.107 所 示 。 


输出 二 维 数 组 $a ; Ar > Array ([0] =>alI 了 = => Aray([O SC 
=> 4) BY 3> Pr > & 回 二 及 
园 出 一 准 吉 委 9a 键 填 7 $a[1] : Array ( [01 => a (J 


图 2.107 二 维 数组 的 输出 


图 关键 技术 


如 果 创 建 的 数组 中 的 元 素 值 都 是 变量 ， 此 数组 称 为 一 维 数组 ， 如 果 创 建 的 数组 元 素 值 仍然 是 数组 ， 那 么 就 
称 为 二 维 数组 。 也 就 是 说 ， 一 个 数组 的 元 素 如 果 仍 是 一 个 一 维 数 组 ， 则 称 这 个 数组 是 二 维 数组 。 
看 设计 过 程 
创建 index.php 文件 。 首 先 定义 二 维 数组 变量 $a 并 为 此 变量 赋值 ， 然 后 利用 print_r0 函 数 实现 二 维 数 组 的 输 
出 ， 其 代码 如 下 : 
六 echo 输出 二 维 数 组 $a: '; 
$a= ee ,b),2=>array('e',d"),3=>array('e',f)); 1/ 创建 一 个 二 维 数组 
Print_r($a)."<br 


echo -0 输出 二 维 数组 $a 键 值 为 1 元 素 $a[1]:“ 
print_r($a[1]); /打印 二 维 数组 键 值 为 1 的 元 素 


> 


国 秘笈 心 法 

心 法 领悟 133: 对 PHP 中 数组 的 理解 。 

PHP 中 的 数组 实际 上 是 一 个 有 序 图 。 该 图 是 一 种 把 values 映射 到 keys 的 类 型 ， 此 类 型 在 很 多 方面 做 了 
优化 ， 因 此 可 以 把 它 当成 真正 的 数组 来 使 用 ， 或 列表 (矢量 ) 、 散 列表 (是 图 的 一 种 实现 ) 、 字 典 、 集 合 、 栈 、 
队列 以 及 更 多 可 能 性 。 因 为 可 以 用 另 一 个 PHP 数组 作为 值 ， 也 可 以 很 容易 地 模拟 树 。 


和 值 级 | 
实例 t 
sx | wn 
力 实例 说 明 
每 个 数组 元 素 都 是 由 键 名 和 值 两 部 分 组 成 的 ， 想 要 获取 它们 可 以 通过 循环 来 实现 。 本 实例 通过 foreach 语句 
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获取 数组 当前 的 键 名 和 值 ， 运 行 结果 如 图 2.108 所 示 。 


EE 
值 为 323 你 对 


图 2.108 ”获取 键 名 值 


图 关键 技术 


数组 中 的 每 个 实例 都 包含 两 项 : 键 和 值 。 其 中 键 可 以 是 数字 、 字 符 串 或 者 数字 和 字符 串 的 组 合 ， 用 于 标识 
数组 中 相应 的 值 ， 而 值 被 称 为 数组 中 的 元 素 ， 可 以 定义 为 任意 数据 类 型 ， 甚 至 是 混合 类 型 ， 最 终 通过 键 来 获取 
相应 的 值 。 


图 设计 过 程 
新 建 index.php 文件 。 首 先 ， 定 义 数组 变量 $array 并 且 为 其 赋值 。 当 单 击 “ 获 取 键 名 ”按钮 时 ， 利 用 foreach 


语句 遍历 数组 并 输出 所 有 元 素 的 键 值 ， 当 单 击 “ 获 取 值 ”按钮 时 ， 同 样 通过 foreach 语句 获取 数组 元 素 的 value 
值 并 且 输 出 ， 其 代码 如 下 : 
< 


hp 
Sarray =array(" 编 程 "=>"123","soft"=>" 你 好 ","456"=>"mingri"); // 定 义 数组 
if($_POST[sub){ // 通 过 POST 方式 传递 参数 
echo " 键 名 为 :"; 
foreach($array as $key => $value){ /| 遍历 数组 
echo $key."&nbsp:&nbspi&nbsp:&nbsp:": // 输 出 键 值 
} 
} 
if($_POST[sub1){ // 通 过 POST 方式 传递 参数 
echo " 值 为 :"; 
foreach($array as $key => $value){ // 遍 历数 组 
echo $value."&nbsp:&nbsp:;&nbsp:&nbsp:": // 输 出 值 
下 
?> 
图 秘笈 心 法 
心 法 领悟 134: 使 用 foreach 语句 的 注意 事项 。 
foreach 语句 只 能 用 于 数组 。 


实例 135 


高 级 | 
| 
| 


趣味 指数 : 位 食 食 食 


国 实例 说 明 


PHP 大 型 的 程序 开发 往往 使 程序 员 焦头烂额 ， 有 时 程序 员 不 确定 自己 定义 的 数组 中 是 否 存 在 需要 的 元 素 。 
本 实例 通过 array_key_exists0 函 数 检 测 数 组 中 是 否 存 在 某 个 值 ， 运 行 结果 如 图 2.109 所 示 。 


Ty 


图 2.109 检测 数组 中 是 否 存在 某 元 素 
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力 关键 技术 
在 PHP 中 ， 检 测 数 组 中 是 否 存 在 某 个 值 ， 使 用 array key_exists0 函 数 ， 其 语法 如 下 : 


bool array key _exists ( mixed key, array search ); 

参数 说 明 : 

mixed key: 检测 元 素 。 

array search: 源 数 组 。 

该 函数 检查 给 定 的 键 名 或 索引 是 否 存在 于 数组 中 。 


图 设计 过 程 
新 建 index.php 文件 ， 定 义 数组 变量 $array 并 为 其 赋值 ， 当 单 击 “ 检 测 ” 按 钮 时 ， 利 用 array_key_exists0 函 
数 判断 接收 到 的 文本 框 信息 是 否 存在 于 指定 的 数组 元 素 中 ,并 且 根 据 返 回 值 给 出 相应 的 提示 信息 ， 其 代码 如 下 : 


<?php 
Sarray =array(" 编 程 "=>"123","soft"=>" 你 好 ","456"=>"mingri"); // 定 义 数组 
这 $_POST[sub]){ /通过 POST 方式 传递 参数 
iflarray_key_exists($_POST[text].Sarray))f // 检 测 是 否 存在 元 素 
echo "<script>alert(' 数 组 中 存在 此 元 素 ):</script>": /提示 
jelsef 
echo "<script>alert( 数 组 中 不 存在 此 元 素 "):</script>"; /| 提示 
} 
} 
> 
国 秘笈 心 ; 


心 法 领悟 135:; array_key_exists0 函 数 的 相关 说 明 。 
array_key_exists() 函 数 在 给 定 的 key 存在 于 数组 中 时 返回 TRUE，key 可 以 是 任何 能 作为 数组 索引 的 值 。 
array_key_existsO 函 数 也 可 用 于 对 象 。 


力 实例 说 明 
本 实例 通过 current0 函 数 获取 数组 中 的 当前 单元 ， 运 行 结果 如 图 2.110 所 示 。 


获取 单元 
PHP 范 例 宝典 


图 2.110 获取 数组 中 的 当前 单元 


| 克 刘 去 ， 


力 关键 技术 
current0 函 数 的 主要 功能 是 返回 数组 中 的 当前 单元 ， 其 语法 如 下 : 


mixed current ( array &array ); 
力 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 数 组 变量 并 为 其 赋值 ， 当 单 击 “获取 单元 ”按钮 时 ， 通 过 currentO 


函数 获取 数组 当前 元 素 ， 其 代码 如 下 : 
和 $array =array(" 编 程 "=>"PHP 范例 宝典 "."soft"=>" 你 好 ","456"=>"mingri"): // 定 义 数 组 
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if($_POST[sub){ /通过 POST 方式 传递 参数 
echo current($array); /获取 当前 数组 中 的 单元 
} 


?> 


| (2) 将 该 文件 存储 于 \MR\02\136 文件 夹 中 ， 命 名 为 mdex.php。 运 行 结果 如 图 2.110 所 示 。 
图 秘笈 心 法 


心 法 领悟 136: 使 用 currentO 函 数 的 相关 说 明 。 

currentO 函 数 返 回 当前 被 内 部 指针 指向 的 数组 单元 的 值 ， 并 不 移动 指针 。 如 果 内 部 指针 指向 超出 了 单元 列表 
的 末端 ，current0 函 数 返 回 FALSE。 如 果 数 组 包含 有 空 的 单元 0 或 者 ""， 空 字符 串 ) ， 则 本 函数 在 碰 到 这 个 单 
元 时 也 返回 FALSE。 


实例 137 


力 实例 说 明 
通过 rand0 函 数 可 以 随机 抽取 数组 中 的 元 素 。 下 面 再 通过 另外 一 个 函数 array_rand0 实 现 从 数组 中 随机 取出 
元 素 ， 运 行 结果 如 图 2.111 所 示 。 


获取 单元 
获取 随机 元 素 PHP 范 
图 2.111 从 数组 中 随机 取出 元 素 


图 关键 技术 


当 用 户 想 从 数组 中 取出 一 个 或 多 个 单元 时 ， 使 用 array_rand0 函 数 是 非常 有 用 的 ， 它 与 rand0 函 数 获取 随机 
数组 元 素 的 原理 大 同 小 异 ， 其 语法 如 下 : 

ined array_ rand (aray input [int nn, req] 

参数 说 明 : 

array input: 传 入 的 数组 。 

int num req: 可 选 参数 ， 定 义 输出 数组 元 素 的 个 数 。 


图 设计 过 程 
(1) 创 建 PHP 脚本 文件 .首先 ,定义 数组 变量 Sarray 并 为 其 赋值 , 当 单 击 “ 获 取 单 元 ”按钮 时 ,通过 array_rand() 
函数 获取 数组 中 的 随机 元 素 值 ， 其 代码 如 下 : 
<2php 


$array =array(" 编 程 "=>"PHP 范例 宝典 ","soft"=>" 明 日 科技 "."456"=>"mingri"); // 定 义 数组 

if($_POST[sub){ /通过 POST 方式 传递 参数 
S$rand keys = array_rand($array, 1); /获取 数组 的 随机 键 值 
echo "获取 随机 元 素 : ".$array[$rand_keys] : /输出 随机 元 素 值 

} 

> 
(2) 将 该 文件 存储 于 \MR\02\137 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.111 所 示 。 
力 秘笈 心 法 


心 法 领悟 137: 使 用 array_rand0 函 数 的 相关 说 明 。 
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array_randO 函 数 在 从 数组 中 取出 一 个 或 多 个 随机 的 元 素 时 相当 有 用 。 它 接受 $array 作为 输入 数组 和 一 个 可 
选 的 参数 num req， 指 明 想 取出 多 少 个 元 素 。 如 果 没 有 指定 ， 默 认为 1。 如 果 只 取出 一 个 ，array_rand0 函 数 返 
回 一 个 随机 元 素 的 键 名 ， 和 否则 就 返回 一 个 包含 随机 键 名 的 数组 。 这 样 用 户 就 可 以 随机 从 数组 中 取出 键 名 和 值 。 


人 二 
国 实例 说 明 


数组 与 数组 之 间 是 彼此 独立 的 ， 但 是 两 个 数组 可 以 合并 到 一 起 成 为 一 个 新 数组 。 本 实例 通过 数组 函数 
array_merge() 实 现 合并 数组 ， 运 行 结果 如 图 2.112 所 示 。 


[2] => Java 编程 3] => CH 编程 4] - 


图 2.112 合并 数组 


图 关键 技术 


数组 的 合并 应 用 的 是 array_merge0 函 数 ， 其 语法 如 下 : 
array array_merge ( array array1 [, array array2 [, array 了 ] ); 

参数 说 明 : 

array array1: 数组 1。 

array array2: 数组 2。 


力 设计 过 程 

新 建 index.php 文件 。 首先 , 定义 两 个 数组 变量 并 为 其 赋值 。 当 单 击 “ 合 并 数组 ”按钮 时 , 利用 array_merge0 
函数 合并 数组 ， 并 打印 合并 后 的 数组 ， 其 代码 如 下 : 

<?php 


Sarray =array(" 编 程 "=>"PHP 范例 宝典 "."soft"=>" 明 日 科技 "."456"=>"mingri"): /定义 数组 1 

echo "数组 1: "; 

print_r(Sarray); /打印 数组 

echo "<br><br>"; 

Sarr = array("PHP 编程 "."Java 编程 "."C# 编 程 "."ASP.NET 编程 "); /定义 数组 2 

echo" 数 组 2: ": 

print r(Sam; // 打 印 数组 

echo "<br><br>"; 

if($_POST[sub) { /通过 POST 方式 传递 参数 
echo "合并 后 的 数组 "; 
Print_r(array_merge($array.$arr)): // 打 印 合并 后 的 数组 

国 } 
、、 
图 秘笈 心 法 


心 法 领悟 138: 使 用 array_mergeO 函 数 的 相关 说 明 。 
array_merge0 函 数 将 一 个 或 多 个 数组 的 单元 合并 起 来 ， 一 个 数组 中 的 值 附加 在 前 一 个 数组 的 后 面 ， 返 回 作 
为 结果 的 数组 。 如 果 输 入 的 数组 中 有 相同 的 字符 串 键 名 ， 则 该 键 名 后 面 的 值 将 覆盖 前 一 个 值 。 如 果 数 组 包含 数 
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字 键 名 ， 后 面 的 值 将 不 会 覆盖 原来 的 值 ， 而 是 附加 到 后 面 。 如 果 只 给 了 一 个 数组 并 且 该 数组 是 数字 索引 的 ， 则 
键 名 会 以 连续 方式 重新 索引 。 


| 


高 级 
起 味 指数 : 贾 页 页 页 


实例 139 


力 实例 说 明 


存在 数组 的 合并 函数 当然 也 就 存在 数组 的 拆 分 函数 。 本 实例 通过 array_chunkO 函 数 实现 数组 的 拆 分 ， 运 行 
结果 如 图 2.113 所 示 。 


> C# 编 程 [站 => ASP:NET 编 程 ) 


拆 分 后 的 数组 : Ar = 让 Array ( [0] => PHB 编 程 [十 了 半 扣 va 编程 ) [1] => Avray; 
(IO 二 C# 编 程 呈 隐隐 天 eg) a 饮 伯 


图 2.113 拆 分 数组 


图 关键 技术 


array_chunk(O) 函 数 可 将 一 个 数组 分 割 成 多 个 ， 其 原理 是 将 原 有 数据 根据 传递 的 参数 不 同 分 割 成 多 个 二 维 数 
组 。array_chunkO 函 数 的 语法 如 下 : 

amray array_chunk ( array input int size [, bool preserve keys] ); 

参数 说 明 : 

array input: 源 数组 。 

int size: 分 割 成 指定 数量 的 数组 。 


看 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 数组 变量 并 为 其 赋值 ， 当 单 击 “ 拆 分 数组 ”按钮 时 ， 打 印 被 拆 分 后 
的 数组 ， 其 代码 如 下 : 
<?php 
$arr = array("PHP 编程 ","Java 编程 "."C# 编 程 ""ASPNET 编程 "); /定义 数组 
echo" 原 数组 : ": 
print_r($arr): /打印 数组 
echo "<br><br>"; 
echo " 拆 分 后 的 数组 : “ 
if($_POST[sub){ // 通 过 POST 方式 传递 参数 
Pprint_r(array_chunk($arr,2))."<br>"; // 拆 分 数组 


?> 


(2) 将 该 文件 存储 于 \MR\02\139 文件 夹 中 ， 命 名 为 index.php。 运 行 结果 如 图 2.113 所 示 。 
秘笈 心 法 


心 法 领悟 139: 使 用 array_chunkO 函 数 的 注意 事项 。 
使 用 array_chunkO 函 数 拆 分 的 数组 ， 最 后 一 个 数组 的 单元 数目 可 能 会 少 几 个 。 
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实例 140 


力 实例 说 明 
通过 for 语句 可 以 遍历 数组 ,下 面 通过 另外 一 种 方法 来 遍历 数组 。 本 实例 通过 list0 和 each0 函 数 实现 遍历 数 


组 ， 运 行 结果 如 图 2.114 所 示 。 


[EL 
Array ( [1] .=> PR e] => PHP 编 程 [0] 二 > 0 >0) 
Array ( [1] = >,Java value] => Java 编 程 [0] 丘 > j=> 塌 


Array ( [1] => 6# [value} => C# 编 程 [0] = 为 2 区 Ba>2) 
Array ( [1] => ASP.NET 编 程 "fyalue] => ASP.NE ‘0] > 区 
[key] => 3) 


图 2.114 遍历 数组 


图 关键 技术 


遍历 数组 的 方法 有 很 多 ， 除 了 使 用 foreach 语句 外 ， 还 可 以 通过 list0 和 each0 函 数 配合 使 用 来 实现 ， 其 相关 
语法 如 下 : 

list0 函 数 把 数组 中 的 值 赋 给 一 些 变量 。 与 array0 函 数 类 似 ， 其 不 是 真正 的 函数 而 是 语言 结构 。list0 函 数 仅 
能 用 于 数字 索引 的 数组 ， 且 数字 索引 从 0 开始， 其 语法 如 下 : 


a 

参数 mixed 为 被 赋值 的 变量 名 称 。 

each() 函 数 ， 返 回 数组 中 当前 指针 位 置 的 键 名 和 对 应 的 值 ， 并 向 前 移动 数组 指针 。 键 值 对 被 返回 为 4 个 单 
元 的 数组 ， 键 名 为 0、1、key 和 value。 单 元 0 和 key 包含 有 数组 单元 的 键 名 ，1 和 value 包含 有 数据 ， 其 语法 


ee 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 当 单 击 “ 遍 历数 组 ”按钮 时 ， 首 先 定义 数组 变量 并 为 其 赋值 ， 然 后 通过 list0 和 
each0 函 数 实现 数组 遍历 并 输出 结果 ， 其 代码 如 下 : 

< 


php 
if($_POST[sub){ // 通 过 POST 方式 传递 参数 
$foo = array("PHP 编程 "."JAVA 编程 ""C# 编 程 ""ASPNET 编程 "); /定义 数组 
for($a = 0:$a < count($foo):$at+){ // 定 义 循环 
Print_r(list($name, $value)=each($fo0)): // 打 印 数组 


} 


2 
(2) 将 该 文件 存储 于 \MR\02\140 文件 夹 中 ， 命 名 为 ndex.php。 运 行 结果 如 图 2.114 所 示 。 
国 秘笈 心 法 


心 法 领悟 140: 使 用 list0 和 eachO 函 数 的 注意 事项 。 
list0 函 数 只 能 用 于 数字 索引 的 数组 。 如 果 内 部 指针 越过 了 数组 的 末端 ， 则 each0 函 数 返回 FALSE。 
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2.11 日 期 和 时 间 


对 日 期 和 时 间 进 行 操作 的 程序 无 处 不 在 ， 特 别 是 在 基于 Web 的 应 用 程序 中 ， 如 表单 提交 的 时 间 、 用 户 登 录 
的 时 间 、 数 据 库 中 数据 的 更 新 和 删除 的 时 间 等 。 想 要 记录 这 些 操作 执行 的 时 刻 ， 就 需要 通过 日 期 和 时 间 来 完成 。 
日 期 和 时 间 在 人 们 的 生活 中 必 不 可 少 ， 同 样 ， 在 互联 网 中 也 是 非常 重要 的 。 


| 
图 实例 说 明 


系统 的 当前 时 间 受 时 区 限制 ， 默 认 情 况 下 是 格林 威 治 时 间 。 用 户 正 确 取得 本 地 时 间 是 很 重要 的 。 本 实例 通 
过 date0 函 数 获 取 系统 的 当前 时 间 ， 运 行 结果 如 图 2.115 所 示 。 


EC 


10:03:34 


2.115 设置 系统 的 当前 时 间 


力 关键 技术 


因为 在 PHP 语言 中 , 日 期 时间 函 数 依赖 于 服务 器 的 地 区 设置 , 而 PHP 默认 设置 的 是 标准 的 格林 威 治 时 间 
( 即 采 用 的 是 零 时 区 ) ， 所 以 ， 如 果 没有 对 PHP 的 时 区 进行 设置 ， 那 么 使 用 日 期 、 时 间 函 数 获取 的 将 是 英国 伦 
敦 本 地 时 间 《〈 即 零 时 区 的 时 间 ) 。 

这 也 是 对 PHP 的 时 区 进行 设置 的 原因 ， 因为 如 果 不 设置 正确 的 时 区 ,那么 PHP 的 日 期 、 时 间 函 数 就 获取 不 
到 正确 的 当地 时 间 。 例 如， 以 东 八 区 为 例 ， 如 果 当 地 使 用 的 是 北京 时 间 ， 那么 在 没有 对 PHP 的 时 区 进行 设置 时 ， 
获取 的 时 间 就 将 比 北京 时 间 少 8 个 小 时 。 

更 改 PHP 语言 中 的 时 区 设置 有 如 下 两 种 方法 。 

(1) 在 php.ini 文件 中 ， 定 位 到 [date] 下 的 “:date.timezone =” 选 项 ， 去 掉 前 面 的 分 号 ， 并 设置 它 的 值 为 当 
地 所 在 时 区 使 用 的 时 间 。 修 改 内容 如 图 2.116 所 示 。 

例如 ， 如 果 当 地 所 在 时 区 为 东 八 区 ， 那 么 就 可 以 设置 “date.timezone =” 的 值 为 PRC、Asia/Hong_ Kong、 
Asia/Shanghai (上 海 ) 或 者 Asia/Urumqi (乌鲁木齐 ) 等 ， 这 些 都 是 东 八 区 的 时 间 。 


是 phpjini - 记事 本 =| 口 | | 
文件 加 


; Defines the default tinezone used by the 


date functions 
ate -tinezone 


2.116 设置 PHP 的 时 区 


设置 完成 后 ， 保 存 文件 ， 重 新 启动 Apache 服务 器 。 
(2) 在 应 用 程序 中 , 在 日 期 、 时 间 函 数 之 前 使 用 date_default timezone_setO 函 数 就 可 以 完成 对 时 区 的 设置 。 
date_default_timezone_set0 函 数 的 语法 如 下 : 


date_default_timezone_set(timezone): 


参数 timezone 为 PHP 可 识别 的 时 区 名 称 ， 如 果 无 法 识别 ， 则 系统 采用 UTC 时 区 。 
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例如 , 设置 北京 时 间 可 以 使 用 的 时 区 包括 PRC (中 华人 民 共 和 国 ) 、Asia/Chongqing (重庆 ) 、Asia/Shanghai 
(上 海 ) 和 Asia/Urumqi (乌鲁木齐 ) ， 这 几 个 时 区 名 称 是 等 效 的 。 


图 设计 过 程 


新 建 index.php 文件 ， 当 单 击 “ 地 区 时 间 ” 按 钮 时 ， 首 先 为 当前 PHP 服务 时 间 设 置 时 区 ， 并 通过 switch 语 
名 根据 地 址 栏 传递 参数 的 不 同 ， 通 过 date(O) 函 数 获 取 不 同 国家 和 地 区 的 时 间 ， 其 代码 如 下 : 


hp 
if($_POST[sub){ 


case "英国 "; 
echo (date("H")-8).":".date(™i:s"); 
break: 


case "日 本 "; 
echo(date("H")+1).":".date("i:s"): 
break: 


case "开罗 "; 
echo(date("H")-6).":".date("i:s"); 
break: 

case "莫斯科 "; 
echo(date("H")-5).":".date("i:s"); 
break; 


} 


2 


国 秘笈 心 法 


心 法 领悟 141: 知识 扩展 。 


// 通 过 POST 方式 传递 参数 
// 设 置 时 区 

/| 条 件 语句 

// 如 果 是 中 国 
/| 输出 时 间 

/| 结束 语句 

// 如 果 是 英国 
/| 输出 时 间 

/| 结束 语句 

// 如 果 是 日 本 
/| 输出 时 间 

/| 结束 语句 

// 如 果 是 开罗 
/| 输出 时 间 

/| 结束 语句 

// 如 果 是 莫斯科 
/| 输出 时 间 

// 结 束 语句 


本 实例 只 是 简单 地 向 用 户 介绍 时 区 及 不 同 地 区 相差 的 小 时 数 ， 在 实际 开发 中 不 能 对 时 间 单 纯 地 进行 算术 运 


算 ， 需 要 使 用 关键 技术 中 提供 的 方法 对 PHP 的 时 
实例 142 


力 实例 说 明 


区 进行 设置 。 


趣味 指数 : 请 请 请 斌 | 


将 日 期 转换 为 时 间 戳 是 将 时 间 进 行 数学 运算 的 重要 手段 。 本 实例 通过 time0 函 数 实现 将 日 期 和 时 间 转 换 为 


时 间 戳 ， 运 行 结 果 如 图 2.117 所 示 。 


当前 时 间 : 


2.117 将 日 期 和 时 间 转 换 为 时 间 戳 


图 关键 技术 


获取 系统 UNIX 时 间 戳 的 方法 有 很 多 ， 使 用 ttme0 函 数 是 比较 常用 的 一 种 方法 ，time0) 函 数 的 语法 如 下 : 


inttime ( void ): 
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该 函数 没有 参数 ， 返 回 值 为 UNIX 时 间 戳 的 整数 值 。 
图 设计 过 程 
创建 index.php 文件 。 首 先 ， 设置 PHP 的 时 区 为 中 国 上 海 ， 然 后 ， 利 用 time0 函 数 获 取 当 前 的 时 间 稚 ， 并 通 
过 echo 语句 输出 时 间 戳 ， 其 代码 如 下 : 


<?php 

date_default_timezone_set("Asia/ShangHai"); // 设 置 时 区 

echo "当前 时 间 : ".date('Y-m-d H:i's): /取得 当前 时 间 

ee "<br> 转 换 成 时 间 惟 为 : "time0: // 转 换 为 时 间 才 
| | 秘笈 心 法 


心 法 领悟 142: 知识 扩展 。 
将 当前 日 期 和 时 间 转 换 为 时 间 戳 的 方法 有 很 多 ， 下 面 通过 strtotimeO 函 数 实现 本 例 功 能 ， 代 码 如 下 : 


<Iphp 
date_default_timezone_ set("Asia/ShangHai"); /设置 时 区 
echo "当前 时 间 : ".date('Y-m-d H:i:s); /设置 当前 日 期 和 时 间 
echo “转换 时 间 惟 为 : "strtotime("now"); /转换 时 间 惟 
2> 
2 
实例 143 : . | 
趣味 指数 : 克 友 友 友 | 


力 实例 说 明 


在 PHP 程序 设计 中 ， 日 期 和 时 间 是 具有 一 定格 式 的 ， 例 如 ， 今 天 是 一 年 的 第 多 少 天 等 。 本 实例 应 用 date0 
函数 通过 传 入 参数 不 同 实现 日 期 和 时 间 的 格式 化 ， 运 行 结果 如 图 2.118 所 示 。 


图 2.118 日 期 和 时 间 的 格式 化 


力 关键 技术 

本 实例 通过 date0 函 数 实现 日 期 和 时 间 的 格式 化 ， 详 细 说 明 请 参见 实例 035。 
图 设计 过 程 

(1) 创建 PHP 脚本 文件 ， 设 置 PHP 的 时 区 为 中 国 上 海 。 然 后 ， 利 用 向 date0 函 数 中 传递 的 参数 不 同 实现 
lh 并 输出 格式 化 后 的 信息 ， 其 代码 如 下 : 


局 default_ timezone_set("Asia/ShangHai"): // 设 置 时 区 
echo "当前 时 间 : "date(Y 年 月 d 日 了 点 i 分 s 秒 A)."<br>": /格式 化 日 期 和 时 间 


echo "本 月 有 ".date(t)." 天 .<br> 今 天 是 一 周 的 第 ".date(w)." 天 ,是 一 年 的 第 ".date(z)." 天 ": 


?> 
(2) 将 该 文件 存储 于 \MR\02\143 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.118 所 示 。 
力 秘笈 心 法 
心 法 领悟 143: 知识 扩展 。 
date0 函 数 还 有 很 多 其 他 的 参数 ， 熟 悉 这 些 参 数 的 使 用 可 以 在 使 用 格式 化 时 间 、 日 期 上 事半功倍 ， 具 体 参数 
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说 明 请 参见 实例 035。 


实例 144 


力 实例 说 明 
在 PHP 语言 中 ， 要 完成 对 两 个 时 间 大 小 的 比较 ， 必 须 先 将 时 间 转 换 为 时 间 戳 ， 可 以 通过 strtotime0 函 数 完 
成 。 本 实例 应 用 strtotime0 函 数 对 两 个 固定 的 时 间 进 行 比较 ， 其 运行 结果 如 图 2.119 所 示 。 


图 2.119 比较 时 间 的 大 小 


图 关键 技术 


PHP 中 应 用 strtotime0 函 数 将 任何 英文 文本 的 日 期 解析 为 UNIX 时 间 戳 ， 其 值 为 相对 于 now 参数 给 出 的 时 
间 ， 如 果 没 有 提供 此 参数 则 用 系统 当前 时 间 ， 此 时 与 实例 142 中 的 time0 函 数 相同 。strtotime0 函 数 的 语法 如 下 : 

int strtotime ( string time [, int now] ): 

该 函数 有 两 个 参数 。 如 果 参 数 time 的 格式 是 绝对 时 间 ， 则 now 参数 不 起 作用 ; 如 果 参 数 time 的 格式 是 相 
对 时 间 ， 其 对 应 的 时 间 就 是 参数 now 来 提供 的 ， 当 没有 提供 参数 now 时 ， 对 应 的 时 间 就 为 当前 时 间 。 如 果 解 析 
失败 ， 则 返回 FALSE。 在 PHP 5.1.0 之 前 的 版 本 中 ， 本 函数 在 失败 时 返回 -1。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 。 首 先 ， 编 写 form 表单 并 设置 当前 时 区 为 中 国 上 海 ， 当 单 击 “ 日 期 比较 ”按钮 时 ， 
运用 strtotime0 函 数 获取 两 个 不 同时 间 点 的 时 间 戳 ， 并 进行 求 差 运算 。 最 后 ， 输 出 相关 提示 ， 其 代码 如 下 : 
<?php 


echo "<form action=" method= post>": /| 输出 表单 

echo "<input type='submit name='sub' value=' 日 期 比较 >"; 

echo "</form>"; 

date_default_timezone_set("Asia/ShangHai"): /设置 时 区 

if($_POST[sub){ // 通 过 POST 方式 传递 参数 
Stime=date("Y 年 m 月 d 日"); /取得 当前 日 期 
S$time_ 1=time0; // 取 得 当前 时 间 玲 
Stime 2 = strtotime("27 June 2014"): /取得 固定 日 期 的 时 间 戳 
if($time 2<S$time_ 1){ /时 间 翼 比较 


echo $time." 比 2014 年 6 月 27 日 大 "; 
Jelse{ 

echo $time." 比 2014 年 6 月 27 日 小 "; 
} 


} 
?> 
(2) 将 该 文件 存储 于 \MR\02\144 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.119 所 示 。 
国 秘 稚 心 ; 


心 法 领悟 144: 使 用 strtotime0 函 数 的 相关 说 明 。 

strtotimeO 函 数 预 期 接受 一 个 包含 美国 英语 日 期 格式 的 字符 串 ， 并 尝试 将 其 解析 为 UNIX 时 间 戳 《 自 
January 1 1970 00:00:00 GMT 起 的 秒 数 ) ， 其 值 相对 于 now 参数 给 出 的 时 间 ， 如 果 没 有 提供 此 参数 则 用 系统 
当前 时 间 。 
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实例 145 


rn FI. 
实例 说 明 
计算 考试 时 间 程 序 是 单纯 地 将 两 个 时 间 点 的 时 间 戳 做 算术 运算 。 本 实例 通过 您 用 时 5 和 答题 

time() 函 数 实现 考试 时 间 的 计算 ， 运 行 结果 如 图 2.120 所 示 。 图 2.120 计算 考试 时 间 

力 关键 技术 


本 实例 的 关键 点 是 tmeO 函 数 的 灵活 运用 。 当 单 击 “ 开 始 答题 ”按钮 时 ， 将 time0O 函 数 获取 的 时 间 戳 存储 到 
SESSION 变量 中 ， 当 单 击 “ 答 题 完毕 ”按钮 时 ， 再 次 通过 time(O) 函 数 获取 系统 的 当前 时 间 戳 。 当 前 时 间 戳 减 去 
开始 定义 的 时 间 戳 ， 就 是 考试 所 用 时 间 。 

力 设计 过 程 

(1) 创建 PHP 脚本 文件 。 首 先 编写 form 表单 并 设置 两 个 提交 按钮 ， 当 每 个 按钮 被 单 击 后 ， 利 用 SESSION 
变量 保存 此 时 的 时 间 玲 并 进行 求 差 运算 ， 然 后 输出 结果 ， 其 代码 如 下 : 

<php 


echo "<form action =" method =post>": /输出 表单 
echo "<input type = submit name='sub’ value=' 开 始 答题 >&nbsp;<input type='submit name='sub_l'value = 答题 完毕 >"; 
echo "</form>"; 
if($_POST[sub){ /通过 POST 方式 传递 参数 
Stime = time(); // 取 得 当前 时 间 玲 
$_SESSION['time'] = $time; /将 时 间 戴 保存 在 SESSION 中 
echo "<script>alert(' 单 击 确定 开始 答题 ");:</script>"; /| 输出 提示 
} 
这 $_ POST[sub_1]){ // 通 过 POST 方式 传递 参数 
iflisset($_SESSION['time']){ // 判 断 SESSION 是 否 存在 
echo "您 用 时 ".(time0-$_ SESSION['time])." 秒 答题 ": /输出 结果 
session_destroy(): /| 销毁 SESSION 
jelsef // 否 则 输出 提示 


echo "<script>alert( 您 还 没有 答题 无 法 结束 ， 请 先 答题 ! ):location href~'index.php'</script>"; 
} 
} 


> 
(2) 将 该 文件 存储 于 \MR\02\145 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.120 所 示 。 
力 秘笈 心 法 


心 法 领悟 145: 知识 扩展 。 
本 实例 运用 SESSION 机 制 保存 考试 的 开始 时 间 ， 然 后 完成 考试 时 间 的 计算 。 有 关 SESSION 机 制 的 详细 讲 
解 请 参考 本 书 第 5 章 的 内 容 。 


本 | 


四 实例 说 明 


倒计时 功能 的 实现 同样 也 是 将 时 间 戳 做 算术 运算 。 本 实例 应 用 strtotime0 函 数 实现 倒计时 程序 ,运行 结果 如 
图 2.121 所 示 。 
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2.121 倒计时 


图 关键 技术 
本 实例 的 关键 点 是 strtotime0) 函 数 的 灵活 运用 ， 详 细 说 明 参 见 实例 144。 
图 设计 过 程 


(1) 创建 PHP 脚本 文件 ， 设 置 当前 时 区 为 中 国 上 海 。 首 先 ， 利 用 time0 函 数 取 得 当前 时 刻 的 时 间 惟 并 保存 
在 变量 中 。 然 后 ， 利 用 strtotimeO 函 数 取 得 2011 年 1 月 1 日 的 时 间 戳 并 保存 在 变量 中 ， 将 两 个 时 间 改 进行 求 差 
ne 其 代码 如 下 : 


default timezone_set("Asia/ShangHai"); /设置 时 区 

echo "当前 时 间 : "date(Y 年 耳 月 d 日 吾 点 i 分 s 秒 )"<br>"; /输出 当前 日 期 

Stime = time(); /取得 当前 时 间 戳 
Stime r= strtotime("1 January 2016"); /取得 指定 日 期 的 时 间 截 


echo " 距 2016 年 元 旦 还 有 <b style= colorred;>".ceil(((Stime r - $time)/(3600*24)))."</b> 天 "; /输出 
了 
(2) 将 该 文件 存储 于 \MR\02\146 文件 夹 下 ， 命 名 为 index.php。 运 行 结果 如 图 2.121 所 示 。 
国 秘笈 心 法 


心 法 领悟 146: 时 间 比 较 的 原理 。 
通过 上 面 几 个 实例 用 户 应 该 明白 ， 其 实 所 有 的 时 间 比 较 归根 结 底 都 是 时 间 戳 的 比较 ， 所 以 掌握 时 间 稚 是 十 
分 重要 的 。 


- 一 一 a 
力 实例 说 明 


闹钟 是 人 们 生活 中 经 常 使 用 的 一 个 小 工具 ， 它 会 在 指定 时 间 叫 你 起 床 。 在 Web 程序 中 ， 也 可 以 应 用 这 个 原 
理 开 发 一 个 “网 页 闹钟 ”， 提 示 用 户 在 指定 的 时 间或 者 时 间 段 内 要 做 什么 工作 。 本 实例 通过 mktimeO) 函 数 实现 
网 页 闹钟 程序 ， 运 行 结 果 如 图 2.122 所 示 。 


图 2.122 网 页 闹钟 


图 关键 技术 


PHP 中 , 应 用 mktimeO 函 数 将 一 个 时 间 转 换 成 UNIX 的 时 间 戳 值 。mktimeO 函 数 根据 给 出 的 参数 返回 UNIX 
时 间 戳 。 时 间 戳 是 一 个 长 整数 ， 包 含 从 UNIX 纪元 到 给 定时 间 的 秒 数 。mktime0 函 数 的 语法 如 下 : 


int mktime ( [int hour [. int minute [. int second [, int month [, int day [. int year [. int is_dst]]]]]]] ): 
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mktime() 函 数 的 参数 说 明 如 表 2.8 所 示 。 
表 2.8 mktime() 函 数 的 参数 说 明 


参数 说 明 

hour 小 时 数 

Iminute 分 钟 数 

Second 秒 数 〈 一 分 钟 之 内 ) 

month 月 份 数 

day 天 数 

year 年 份 数 ， 可 以 是 2 位 或 4 位 数字 ，0~69 对 应 于 2000~2069，70~100 对 应 于 1970~2000 
is_dst 在 夏令 时 可 以 被 设 为 1， 如 果 不 是 则 设 为 0;， 如 果 不 确定 是 否 为 夏令 时 ， 则 设 为 -1 默认 值 ) 


图 设计 过 程 
(1) 创建 index.php 文件 。 首 先 定义 PHP 时 区 为 中 国 上 海 ， 然 后 编写 form 表单 ， 通 过 mktime0 函 数 实现 
获取 当前 的 时 间 戳 ， 其 代码 如 下 : 


<?php 
echo "<table border="1' bordercolor=#FF0000' cellspacing="0' align='center><tr><td>"; /输出 表格 
echo "<h2 style='color:#0033FF> 曾 钟 程序 </h2>"; /输出 标题 
date_default_timezone_set("Asia/ShangHai"); /设置 时 区 
echo "<h6 style='color:red> 今 天 是 ".date("Y-m-d H:i:s")."</h6>"; // 输 出 当前 时 间 
echo "<form action=" method= post>": // 输 出 表单 
echo "<input type='text name='textl' size='2> 年 <input type='text name='text2' size='2> 月 "; 
echo "<input type='text name='text3' size=2> 日 <br><input type='text name='text4' sizc= 2> 时 ": 
echo "<input type='text’ name='text$' size="2> 分 <input type='text name='text6' size=2> 秒 <br>"; 
echo "<input type='submit’ name='sub' value= 定 时 >"; 
echo "</form>"; 
$a=$_POST[text1]; // 取 得 文本 框 内 容 
$b=$_POST[text2]; // 取 得 文本 框 内 容 
$c =$_POST[text3]: // 取 得 文本 框 内 容 
$d=$_POST[text4]: // 取 得 文本 框 内 容 
$e =$_POST[text5]: // 取 得 文本 框 内 容 
$f=$_POST[text6]: // 取 得 文本 框 内 容 
Stime = date(mktime($d, $e, Sf $b. $c, $a)): /获取 时 间 戳 
$_SESSION[time] = Stime: /保存 在 SESSION 中 
这 $_ POST[sub]){ /通过 POST 方式 传递 参数 
echo"<script>window.location.href="in.php';</script>"; // 跳 转 
echo "</td></tr></table>": 
> 
(2) 创建 n.php 文件 ， 其 代码 如 下 : 
<?php 
date_default_timezone_set("Asia/ShangHai"): /设置 时 区 
S$time 1 = time(); /取得 当前 时 间 戳 
这 $_SESSION[time] < $time_1){ 1/ 判断 条 件 
echo "<script>alert(' 时 间 一 去 不 复 返 ):location href='index.php'</script>": // 输 出 提示 
Jelse{ 
if($_SESSION['time] — Stime 1){ // 判 断 条 件 
echo "<script>alert( 今 天 是 XXX 生日 ):</script>": // 输 出 提示 
Jelse{ /输出 提示 


> 


echo "距离 XXX 的 生日 还 有 ".ceil((($_SESSION['time']-$time_1)/(3600*24)))." 天 ": 


站 
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心 法 领悟 147: 不 同 版 本 的 操作 平台 对 UNIX 时 间 戳 的 支持 。 

PHP 为 UNIX 时 间 戳 的 处 理 提供 各 种 函数 。 到 目前 的 PHP 版 本 为 止 ， 由 于 任何 已 知 Windows 版 本 以 及 一 
些 其 他 系统 均 不 支持 负 的 时 间 戳 ， 因 此 在 Windows 中 无 法 表示 1970 年 1 月 1 日 之 前 的 时 间 。 因 为 目前 UNIX 
时 间 戳 是 以 32 位 二 进 制 表示 的 ， 其 范围 为 -2147483648 ~ +2147483647) ， 因 此 ， 目 前 UNIX 时 间 稚 可 表示 的 最 
大 时 间 为 2038 年 1 月 19 日 3 点 14 分 7 秒 ， 该 时 刻 时 间 惟 为 2147483647， 对 于 该 时 刻 之 后 的 时 间 ， 需 要 扩展 
表示 UNIX 时 间 戳 的 二 进 制 位 数 。 


实例 148 


力 实例 说 明 

在 百度 中 ， 当 执行 一 个 查询 操作 时 ， 获 取 到 查询 结果 后 页 面 中 就 会 出 现 一 行文 字 ， 提 示 根 据 关 键 字 搜索 到 
多 少 个 结果 ， 以 及 搜索 所 用 的 时 间 。 这 个 时 间 就 是 程序 在 执行 该 搜索 时 所 用 的 时 间 ， 那 么 它 是 如 何 实现 的 呢 ? 
下 面 就 模仿 它 来 做 一 个 计算 程序 运行 时 间 的 小 程序 ， 其 运行 结果 如 图 2.123 所 示 。 
下 高 2016 年 奥运 会 乔 蕊 还 有 450 闫 170[ 


倒计时 程序 的 运行 时 间 为 0.000311036804312 秒 


图 2.123 计算 程序 运行 时 间 


图 关键 技术 


本 实例 的 关键 点 是 strtotime() 函 数 的 使 用 ， 其 原理 是 : 首先 在 执行 查询 操作 之 前 定义 一 个 时 间 ， 将 其 精确 到 
微 秒 ， 然 后 执行 查询 操作 ， 接 着 在 查询 功能 执行 完毕 后 再 次 获取 一 个 时 间 ， 同 样 精确 到 微 秒 ， 应 用 后 获取 的 时 
间 减 去 最 初 获 取 的 时 间 ， 就 是 本 次 查询 所 用 的 时 间 。 


力 设计 过 程 
创建 index.php 文件 。 首 先 定义 nan_time0 函 数 ， 获 取 系 统 当前 的 时 间 戳 。 然 后 调用 run_time0 方 法 ， 获 取 当 


前 时 间 戳 ， 接 着 运行 程序 。 最 后 ， 再 次 调用 run_time0 函 数 ， 获 取 系统 当前 时 间 ， 并 且 输 出 差 值 ， 获 取 程序 的 运 
行 时 间 ， 其 代码 如 下 : 


<?php 

请 ”声明 ran_time0 函 数 

通过 microtime() 函 数 获取 当前 时 间 的 微 秒 数 和 时 间 玲 

应 用 explode0 函 数 将 mierotime0 函 数 返回 的 字符 串 进行 分 隔 ， 返 回 一 个 数组 
包括 两 个 元 素 ， 一 个 元 素 是 当前 时 间 的 微 秒 数 ， 另 一 个 是 当前 时 间 的 时 间 戳 
应 用 list0 函 数 将 explode0 函 数 返回 的 数组 值 赋 给 指定 的 变量 

最 后 ， 获 取 两 个 变量 值 的 和 

4 


function run_timeO{ 
list($msec. $sec) = explode(" ", microtime()): // 使 用 explode0 函 数 返 回 两 个 变量 
retum ((float)$msec + (float)$sec): /返回 两 个 变量 的 和 
} 
$start_time = run_time(); // 第 一 次 运行 un_time0 函 数 
记 ”运行 PHP 代 码 段 */ 
Stimel = strtotime(date( "Y-m-d")):; // 当 前 的 系统 时 间 
Stime2 = strtotime("2016-08-05"); // 奥 运 会 的 开幕 时 间 
$sub2 = ceil(($time2 - Stime1) /86400): 1/(60 秒 *60 分 *24 小 时 ) 秒 /天 
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echo "距离 2016 年 奥运 会 开幕 还 有 <font color=red>$sub2 <Jfont> 天 !: 


话 市 于 于 再 刘 于 本 于 本 本 素 本 本 


Send_time = run_time(); // 再 次 运行 run_time0 函 数 
?> 

<!-- 输出 差 值 ， 获 取 程序 的 运行 时 间 --> 

倒计时 程序 的 运行 时 间 为 <font color=blue> <?php echo ($end time - $start_time); ?> </font> 秒 

be 


国 秘笈 心 法 


心 法 领悟 148: 在 PHP 中 应 用 日 期 、 时 间 函 数 时 的 注意 事项 。 

加 ”在 配置 PHP 时 , 进行 正确 的 时 区 设置 , 这 样 就 不 会 在 输出 时 间 时 出 现 输出 结果 与 当地 时 间 不 符 的 问题 。 

回 ”在 正确 地 配置 了 PHP 的 时 区 之 后 ， 就 要 使 用 日 期 、 时 间 函 数 获 取 日 期 、 时 间或 者 对 应 的 时 间 惟 ， 那 么 
必须 明确 一 个 日 期 、 时 间 在 不 同 的 操作 系统 中 的 有 效 范围 ， 避 免 出 现 获取 超出 范围 的 日 期 、 时 间 数 据 
的 现象 。 

回 ” 有 效 的 时 间 戳 范围 是 格林 威 治 时 间 1901 年 12 月 13 日 20:45:54~2038 年 1 月 19 日 03:14:07( 此 范围 符 

合 32 位 有 符号 整数 的 最 小 值 和 最 大 值 ) 。 

在 Linux 系统 中 此 范围 限制 为 1901 年 12 月 13 日 -2038 年 1 月 19 日 。 

在 Windows 系统 中 此 范围 限制 为 1970 年 1 月 1 日 -2038 年 1 月 19 日 。 

在 通过 日 期 、 时 间 函 数 获取 日 期 、 时 间或 者 时 间 戳 时， 如 果 没 有 指定 时 间 戳 ， 那 么 获取 的 是 本 地 时 间 。 


图 回回 
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Web 页 面 交 互 


第 3 章 Web 页 面 交 互 


3.1 获取 表单 元 素 的 值 


获取 表单 元 素 提交 的 值 是 表单 应 用 中 最 基本 的 操作 方法 , 通过 获取 表单 元 素 提交 的 值 可 以 实现 很 多 的 功能 
例如 ， 添 加 用 户 注 册 信息 、 提 交 用 户 登录 信息 、 添 加 学 生 详细 信息 等 。 下 面 通过 具体 实例 来 介绍 获取 表单 元 素 
提交 的 值 在 PHP 中 的 应 用 。 


力 实例 说 明 


论坛 是 许多 网 站 不 可 或 缺 的 模块 之 一 ， 它 为 人 们 相互 之 间 进 行 各 种 沟通 和 交流 提供 了 一 个 空间 。 设 计 论坛 
模块 的 第 一 个 步骤 就 是 设计 论坛 登录 界面 ， 让 用 户 根据 自 己 注册 的 用 户 名 和 密码 登录 论坛 。 在 本 例 中 笔者 设计 
了 一 个 简单 的 论坛 登录 界面 ， 效 果 如 图 3.1 所 示 。 


3.1 登录 界面 


图 关键 技术 


在 设计 论坛 登录 界面 时 ， 主 要 采用 表格 标签 进行 界面 布局 ， 设 计 一 个 3 行 2 列 的 表格 ， 如 图 3.2 所 示 。 


用 户 志 了 
密 码 | i 


图 3.2 利用 表格 标签 布局 


这 样 , 一 个 论坛 登录 界面 的 轮廓 就 形成 了 。 接 下 来 还 需要 为 表格 设置 背景 图 像 , 利用 表格 标签 的 background 
属性 设置 即 可 ， 代 码 如 下 : 

<table width="392px" height="249px" align="center"><tr><td background="pic/tablebk jpe"> 
图 设计 过 程 

(1) 利用 Dreamweaver 开发 工具 创建 一 个 动态 PHP 页 ， 将 其 保存 为 index.php。 

(2) 添加 一 个 表单 ， 在 表单 中 插入 一 个 3 行 2 列 的 表格 ， 并 调整 表格 各 行 的 高 度 和 列 的 宽度 。 

(3) 设置 表格 的 align 属性 为 center， 使 得 表格 在 表单 中 始终 居中 显示 。 

(4) 向 表格 单元 格 中 输入 用 户 名 称 和 密码 信息 ， 并 添加 文本 字段 和 按钮 。 

(5) 设置 “密码 ”文本 字段 的 类 型 (type) 属性 为 password， 使 其 以 掩 码 的 形式 隐藏 真实 密码 。 

(6) 实例 主要 代码 如 下 : 


q 
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<form action="" method="post"> 
<table align="center"> 
<tr><td> 用 户 名 <itd><td><input type="text" name="te" size="20" /></td></tr> 
<tr><td> 密 &nbsp;&nbsp; 码 </td><td><input type="password" name="tex" size="22" /></td></tr> 
<tr><td align="left"><input class="two"type="submit" name="sub" valuec="&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:" /></td> 
<td align="left"><input class="three" type="reset" name="res" value="&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp:" /></td></tr> 
</table> 
</form> 


秘笈 心 ; 


心 法 领悟 149: 密码 框 与 文本 字段 宽度 不 一 致 的 解决 方案 。 

许多 初学 人 员 都 会 遇 到 这 种 情况 ， 在 设计 时 密码 框 的 宽度 与 文本 字段 宽度 相同 ， 但 是 在 浏览 器 中 显示 则 不 
相同 。 解决 方 法 是 在 密码 框 和 文本 字段 中 指定 统一 的 CSS 样式 , 即 设置 class 属性 。 在 PHP 页 面 中 添加 一 个 CSS 
样式 : 

<style type="text/css"> 

i 

width : 200px; 


这 样 ， 问 题 就 解决 了 。 


高 级 
趣味 指数 : 庚 庚 育 商 


实例 150 


力 实例 说 明 


许多 大 型 网 站 为 了 吸引 用 户 ， 会 分 配 一 些 空间 供用 户 使 用 。 例 如 ， 大 家 经 常 使 用 的 电子 邮箱 、QQ 个 人 空 
间 等 。 为 了 能 够 让 用 户 在 个 人 空间 中 放置 自己 的 内 容 ， 网 站 都 会 提供 文件 、 图 片 等 信息 的 上 传 功能 。 例如 在 QQ 
个 人 空间 中 ， 用 户 可 以 上 传 自己 的 照片 ， 供 好 友 欣 赏 。 本 实例 利用 文件 域 实 现 图 片 的 上 传 功能 ， 效 果 如 图 3.3 
所 示 。 


se 


不 断 升级 的 炉 心 开发 资源 库 ， 为 您 开发 提供 最 系统 、 最 全 面 、 最 权 左 的 开发 撤 


档 和 矶 用 文章 ， 解 决 业 技 术 坦 不 要 .技术 
A 不 全 面 、 挝 术 无 应 用 委 开 发 难 胡 和 困扰 。 
[| 


图 3.3 可 以 上 传 图 片 的 表单 


力 关键 技术 


在 本 例 中 ， 实 现 照片 上 传 的 主要 方式 是 利用 文件 域 让 用 户 加 载 本 地 文件 ， 然 后 应 用 PHP 函数 
move_uploaded_file0 实 现 文件 的 上 传 ， 效 果 如 图 3.4 所 示 。 


Fampowampo\htdocs Wh Ea 3 


图 3.4 文本 域 加 载 本 地 文件 


@ 
mw 
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move uploaded file() 函 数 可 将 上 传 的 文件 移动 到 新 位 置 ， 其 语法 如 下 : 


bool move_uploaded file ( string filename, string destination ); 
参数 说 明 : 

string filename: 指定 的 文件 是 合法 的 上 传 文件 。 
string destination: 定义 上 传 文件 的 名 称 。 


图 设计 过 程 
(1) 创建 动态 PHP 文件 ， 命 名 为 index.php。 


(2) 添加 一 个 表单 ， 将 type 属性 设置 为 file， 代码 如 下 : 


<form action="" method="post" enctype="multipart /form-data"> 
<input type="file" name="upfile" size="20" /> 


<input class="two"type="submit" name="sub" value="&nbsp:é&nbsp;éenbsp:&nbsp; Genbsp;&nbsp;éenbsp:" /> 


</form> 
(3) 利用 <table> 标 签 编写 网 页 框架 。 
(4) 利用 编码 实现 上 传 功能 ， 核 心 代码 如 下 : 


<php 
if($_POST[sub){ 
if($_FILES['upfile]['name] — "){ 
echo "<script>alert( 上 传 内 容 为 空 );:</seript>"; 
jslsef 
Sinfo =$_FILES['upfile]: 
ifSinfof'size]> 0 && Sinfo['size] < 1024 * 8000){ 
Sdir = "upfiles/"; 
Sname = $info['name']: 
Srand = rand(0,10000000); 
Sname = $rand.date(YmdHis) $name: 
Spath = upfiles/,Sname; 
(tis_dir($dir)){ 
mkdir($dir): 
} 


Smove = move_ uploaded_file(Sinfo[tmp_name].Spath; 


if($move — true){ 
echo "<script>alert(' 上 传 文件 成 功 ):</script>"; 
} 
jelse{ 
echo "<script>alert( 上传 文件 过 大 ");</script>"; 
} 


} 
?> 


国 秘笈 心 法 
心 法 领悟 150: 解决 上 传 文件 重 名 问题 。 


// 单 击 “ 上 传 ”按钮 
1/ 判断 上 传 文件 名 称 是 否 为 空 


// 将 上 传 文件 信息 保存 在 数组 中 
1/ 判断 上 传 文件 的 大 小 

// 定 义 变量 

1/ 设 定 文件 名 称 


1/ 判断 文件 夹 是 否 存在 ， 如 果 不 存在 则 创建 一 个 文件 夹 


// 将 上 传 文件 移动 到 指定 位 置 


如 果 用 户 建立 个 人 网 站 ， 人 允许 他 人 上 传 文件 到 服务 器 中 ， 但 是 每 一 个 浏览 网 站 的 用 户 并 不 知道 服务 器 中 是 
否 存 在 与 即将 上 传 的 文件 重 名 的 文件 。 大 家 都 知道 ， 在 Windows 系统 下 ， 同 一 个 文件 夹 中 不 允许 两 个 同名 文件 
的 存在 ， 这 就 使 得 用 户 上 传 的 文件 名 必须 是 独一无二 的 。 笔 者 为 上 传 文件 的 名 称 设置 了 如 下 代码 : 


Sname = $info['name']; 

Srand = rand(0.10000000): 

Sname = Srand date(YmdHis).Sname: 
$path = "upfiles/.$name: 


在 一 般 情况 下 ， 这 样 可 以 避免 上 传 文件 重 名 的 现象 


// 设 定 文件 名 称 
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力 实例 说 明 
POST 方法 是 提交 表单 元 素 的 方法 之 一 ， 是 程序 员 提交 表单 的 主要 途径 。 运 行 本 实例 ， 效 果 如 图 3.5 所 示 。 


三 

从 软件 工 各 9 入 习 、 玫 入 大 目的 开发 届 序 ， 其 统 、 全 画 地 介绍 项 目的 开 并 3 
对 项 目 开发 应 用 的 知识 训 进 行 详细 讲解 ， 在 酚 近 当前 项 目 开发 过 程 的 于 而 
0 


图 3.5 通过 POST 方法 提交 表单 元 素 


图 关键 技术 


本 实例 主要 是 通过 定义 form 表单 的 method 属性 实现 ， 方 法 如 下 : 
<form action=" method="post"> 
看 设计 过 程 
(1) 编写 脚本 文件 index.php。 利 用 <table> 标 签 建 立 网 页 框架 ， 引 入 CSS 文件 。 


(2) 编写 表单 ， 将 提交 方法 定义 为 post， 代 码 如 下 : 
<form action="" method="post"> /提交 方法 为 post 
<br> 
Ea <input class="one" type="text" name="te" size="20" /> 


i Rnbsp: 码 : <input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" valuc="&nbsp:&nbsp:" /> 
<input class="three" type="reset" name="res" valuc="&nbspi&nbsp:" /> 

</form> 


国 秘笈 心 法 


心 法 领悟 151: 为 什么 POST 方法 是 程序 员 处 理 表单 程序 的 首选 。 
POST 方法 与 GET 方法 不 同 ， 虽 然 都 是 采用 地 址 栏 传递 参数 的 方式 ， 但 是 通过 POST 方式 传递 的 参数 在 地 
址 栏 中 是 不 可 见 的 ， 这 样 就 大 大 降低 了 网 站 或 者 程序 的 外 来 因素 的 威胁 。 


高 级 | 
Ne be 


实例 152 


四 实例 说 明 


实例 151 介绍 了 如 何 通过 POST 方法 提交 表单 元 素 , 本 实例 讲解 如 何 通过 $_POST 方法 获取 表单 元 素 。 运行 
本 实例 ， 效 果 如 图 3.6 所 示 。 


里 
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三 全 


从 软件 工程 的 角度 ， 近 第 项 目的 开发 里 序 ， 系 统 、 全 面 她 介绍 项 目的 开发 六 
对 项 目 开 发 应 用 的 知识 点 进行 详细 讲解 ， 在 家 所 当前 项 目 开发 过 程 的 基础 上 
的 拓展 电 梭 ， 进 行 独立 开发 ! 


图 3.6 通过 $ POST 方法 获取 表单 元 素 


图 关键 技术 


本 实例 主要 是 利用 预定 义 变量 $_POST， 该 变量 是 一 个 自动 全 局 变量 ， 即 它 在 所 有 的 PHP 脚本 中 都 有 效 。 
本 实 袍 通过 尝 击 按钮 实现 访 问 文本 框 信息 的 代码 如 下 : 


a 100px" align="center"><?php echo $_POST[te]:2></td> 
es align="center"><?php echo $_POST[pwd]:?></td> 


图 设计 过 程 
(1) 编写 脚本 文件 index.php。 通 过 <table> 标 签 编写 网 页 框架 ， 引 入 CSS 文件 ， 建 立 表 单 ， 代 码 如 下 : 


<form action="" method="post"> 
<br> 


用 户 名 : <input class="one" type="text" name="te" size="20" /> 
<b> 
密 &nbsp;&nbsp; 码 : <input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" value="&nbsp; " /> 
<input class="three" type="reset" name="res" value="&rnbsp:" /> 

</form> 

(2) 当 单 击 “ 确 定 ” 按 钮 时 ， 程 序 首先 判断 文本 框 和 密码 框 信息 是 否 为 空 ， 如 不 为 空 ， 输 出 通过 $_ POST 
方法 获取 的 数据 ， 核 心 代码 如 下 : 
<php 


ifS_POST[sub]){ / 境 击 按钮 


if($_POST[te] 一 "1 $_POST[pwd] — ""): / 济 断 文本 框 和 密码 框 是 否 为 空 
站 全 二 全 
Jelse{ 
‘<table border="1" bordercolor="#0000CC" cellspacing="0" width="200px"> 
<tr> 
<td align="center"> 用 户 名 </td> 
<td align="center"> 密 码 </td> 
<t> 
<tr> 
<td width="100px" align="center"><?php echo $_POST[te]:?></td> 
<td width="100px" align="center"><?php echo $_ POST[pwd]:?></td> 
<ltr> 
</table> 
<?php 
} 
} 
?> 
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心 法 领悟 152: 超级 全 局 变量 $_ POST。 
虽然 $S POST 是 一 个 全 局 变量 ， 但 是 在 访问 的 时 候 不 需要 使 用 关键 字 global。 
高 级 
趣味 指数 : 但 伍 


力 实例 说 明 


GET 方法 是 提交 表单 元 素 的 另 一 种 方法 ， 这 种 方法 虽然 不 是 程序 员 提 交 表 单 的 首选 ， 但 是 在 日 常 的 程序 开 
发 过 程 中 也 是 很 实用 的 。 运 行 本 实例 ， 效 果 如 图 3.7 所 示 。 


习 专业 缩短 苞 能 


标准 厦 以 上 版 本 浊 供 实时 开 级 。 轻 松 襄 受 阴 | 
料 技 开 发 团队 的 开发 成 里 和 经 灶 ， 关 
ECDCLESTT 


图 3.7 通过 GET 方法 提交 表单 元 素 


力 关键 技术 
本 实例 主要 是 通过 定义 form 表单 的 method 属性 来 实现 ， 定 义 方法 如 下 : 


<form action="" method="get"> 
力 设计 过 程 
(1) 编写 脚本 文件 index.php， 利 用 <table> 标 签 建 立 网 页 框架 ， 引 入 CSS 文件 。 
(2) 编写 表单 ， 将 提交 方法 定义 为 get， 全 证 和 
<form action="" method="get"> /提交 方法 为 get 
有 名 <input class="one" type="text" name="te" size="20" /> 


a <input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" value="&enbsp: 党 
<input class="three" type="reset" name="res" value="&nbsp: " 

</form> 


国 秘笈 心 ; 
心 法 领悟 153: GET 方法 与 POST 方法 的 本 质 区 别 。 


当 用 户 提交 表单 时 ， 观 察 GET 方法 和 POST 方法 在 地 址 栏 的 区 别 ，POST 方法 不 会 有 任何 变化 , 而 GET 方 
法 将 在 地 址 栏 内 显示 如 图 3.8 所 示 的 内 容 。 


联 Mtp /ocahost/WR/03/0058006/in php?tecarepdarsoftasabz 


本 


图 3.8 GET 方法 提交 地 址 栏 变化 


第 3 章 Web 页 面 交互 
虽然 传递 内 容 经 过 一 些 加 密 处 理 ， 但 也 近乎 是 明文 地 将 内 容 显示 出 来 ， 是 非常 不 安全 的 行为 。 


力 实例 说 明 
通过 上 面 实例 的 学 习 ， 相 信用 户 已 经 掌握 了 什么 是 GET 方法 以 及 如 何在 表单 中 使 用 GET 方法 ， 下 面 将 通 
过 $_GET 方法 向 用 户 演示 如 何 获取 表单 元 素 ， 如 图 3.9 所 示 。 
弛 类 学 汀 专业 编程 技能 
于 准 版 以 上 陋 本 灵 殿 实时 天 级 ， 既 松 讲 县 其 | 


科技 弄 尖 团 随 的 开发 成 果 积 色 圣 ， 并 
可 理 型 因 全 开 兴 志 它 折 全 班 
本 


图 3.9 通过 $_ GET 方法 获取 表单 元 素 


图 关键 技术 


本 实例 主要 应 用 预定 义 变量 $_GET 实现 ， 本 变量 是 一 个 自动 全 局 变量 ， 即 它 在 所 有 的 PHP 脚本 中 都 有 效 。 
本 实例 通过 单 击 “确定 ”按钮 ， 应 用 $_GET 方法 获取 文本 框 提交 的 数据 ， 其 代码 如 下 : 


i align="center"><?php echo s GET[te]:?></td> 
<td width="100px" align="center"><?php echo $_GET[pwd]:?></t 
<ir> 


图 设计 过 程 
(1) 编写 脚本 文件 index.php。 通 过 <table> 标 签 编写 网 页 框架 ， 引 入 CSS 文件 ， 建 立 表单 ， 代 码 如 下 ; 


<form action="in.php" method="get"> 
Se 户 名 : <input class="one" type="text" name="te" size="20" /> 


Ee &nbsp: 码 : <input class="one" type="password" name="pwd" size="20" /><br> 
<input class="two" type="submit" name="sub" valuec="&nbsp:" /> 
<input class="three" type="reset" name="res" value="&nbsp:" /> 

</form> 


(2) 当 单 击 “ 确 定 ”按钮 时 ， 程 序 首先 判断 文本 框 和 密码 框 信息 是 否 为 空 ， 当 不 为 空 时 ， 输 出 通过 $_GET 
方法 获取 的 数据 ， 核 心 代码 如 下 : 
<? 


hp 
ifS_GET[sub]){ // 单 击 按钮 
if($ ent ||$_GET[pwd] 一 "| // 判 断 文本 框 内 容 
echo "<script>alert( 文 本 框 不 1 


a 
Jelse{ 


<table border="1" bordercolor="#0000CC" cellspacing="0" width="200px"><tr><td align="center’> 用 户 名 </td><td align="center"> 密 码 <jtd></tr> 
<tr><td width="100px" align="center"><?php echo $_GET[te]:?></td><td width="100px" align="center"><?php echo 
$_GET[pwd]:?></td></tr></table> 

<?php 


} 
} 
?> 


@” 
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国 秘笈 心 法 


心 法 领悟 154: 超级 全 局 变量 $_GET。 
与 全 局 变量 $_POST 一 样 ，$_GET 方法 也 不 需要 使 用 关键 字 global 来 访问 。 通 过 $_GET 方法 还 可 以 获取 到 
超 链接 传递 的 参数 值 。 


3.2 文本 框 组 件 的 应 用 


文本 框 组 件 是 用 来 输入 任何 类 型 的 单行 文本 、 数 字 或 字母 数据 的 文本 域 。 在 进行 程序 设计 过 程 中 ， 经 常 使 
用 文本 框 组 件 来 获取 用 户 输入 的 信息 。 下 面 通过 具体 实例 来 说 明文 本 框 组 件 在 PHP 中 的 应 用 。 


ee ee 


趣味 指数 : 袜 食 食 食 


力 实例 说 明 


在 开发 网 站 的 过 程 中 ， 一 般 涉及 用 户 注册 的 网 站 模块 都 有 一 个 用 户 注册 的 服务 条 款 ， 个 别 的 服务 条 款 以 
整个 网 页 进行 显示 ， 但 是 有 的 网 站 因 服 务 条 款 篇 幅 过 长 ， 不 适合 使 用 这 种 方式 ， 最 好 的 解决 方法 是 以 文本 域 
的 形式 来 显示 ， 既 可 节省 页 面 ， 又 美观 大 方 。 运 行 本 实例 ， 在 文本 域 中 显示 用 户 注册 的 服务 条 款 ， 运 行 效果 
如 图 3.10 所 示 。 


3.10 ”以 文本 域 形式 显示 数据 


力 关键 技术 
本 实例 主要 应 用 表单 中 的 文本 域 显示 信息 ， 主 要 就 是 设置 文本 域 的 初始 值 ， 代 码 如 下 : 


<textarea name="test" cols="45" rows="8" id- test'><?php echo $myrowltext]:?></textarea> 
参数 说 明 : 

name: 文本 域 的 名 称 。 

cols: 文本 域 的 字符 宽度 。 

rows: 文本 域 显示 的 行 数 。 


力 设计 过 程 
编写 脚本 文件 ， 编 写 文本 域 代码 ， 并 通过 PHP 变量 传递 初始 值 ， 代 码 如 下 


<pip 
$str "用 户 不 得 发 布 违反 国家 行政 法 规 的 内 容 。 /定义 变量 
不 得 发 布 违反 社会 道德 的 内 容 。"; 


> 
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<textarea name="txt" id="one" cols="30" rows="6"><?php echo $str:?></textarea> /传递 初始 值 
<b> 
<br> 
<input type="submit" name="agreen" id="agreen" value=" 接 受 (8)"” disabled="disabled"/> 
Rnbspi&nbsp:&nbsp:&nbsp: 
<input type="submit" name="disagreen" id="disagreen" value=" 不 接 受 " /> 
</div> 
</form> 


图 秘笈 心 法 


心 法 领悟 155: 文本 域 标签 的 初始 值 。 
文本 框 标签 和 其 他 一 些 标签 设置 初始 值 的 方法 是 将 初始 内 容 写 在 value 属性 中 , 而 文本 域 标签 的 初始 值 内 容 
是 写 在 文本 域 的 开始 和 结束 标签 之 间 。 


a 


起 味 指数 :页 廊 宙 宙 


实例 156 


力 实例 说 明 


在 网 站 的 论坛 或 意见 箱 中 ， 留 言 的 内 容 通常 都 是 在 文本 域 中 输入 的 ， 而 文本 域 不 具有 限制 用 户 输入 最 多 字 
符 数 的 功能 ， 因 此 必须 由 开发 人 员 编写 代码 进行 控制 。 运 行 本 实例 ， 在 “意见 内 容 ” 文 本 框 中 只 能 输入 1000 个 
字 节 ， 即 1000 个 英文 字母 或 500 个 中 文 汉字 ， 用 户 在 文本 框 中 每 输入 一 个 字符 ， 下 面 的 字 节 位 置 都 将 自动 计算 
已 输入 字 节 数 和 剩余 字 节 数 ， 运 行 结果 如 图 3.11 所 示 。 


图 3.11 限制 文本 域 输入 的 字符 个 数 


图 关键 技术 


要 实现 限制 多 行文 本 域 输入 的 字符 个 数 ， 关 键 是 应 用 onKeyDown 事件 和 onKeyUp 事件 ， 调 用 自 定义 的 
JavaScript 函数 StatByte0 来 限制 输入 的 最 多 字符 数 并 计算 已 用 字 节 数 和 剩余 字 节 数 。 
图 设计 过 程 
(1) 创建 一 个 企业 内 部 意见 箱 的 文本 框 ， 代 码 如 下 : 
<textarea name="suggestions" cols="30" rows="5" class="wenbenkuang" id="suggestions"></textarea> 
(2) 添加 显示 字 节 数 的 文本 框 ， 包 括 最 大 字 节 数 、 已 用 字 节 和 剩余 字 节 ， 注 意 此 时 应 该 将 这 3 个 文本 框 设 
置 为 停 用 状态 ， 不 允许 用 户 修改 ， 代 码 如 下 : 
最 大 字 节 数 : 
<input name="maxs" type="text" disabled class="noborder" id="maxs"” value="1000" size="4"> 
ee ns type="text" disabled class="noborder" id="used"” value="0" size="4"> 
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剩余 字 节 : 
<input name="remain" type="text" disabled class="noborder" id="remain" value="1000" size="4"> 


(3) 编写 自 定义 的 JavaScript 函数 StatByte0 用 于 判断 用 户 输入 的 字符 数 是 否 大 于 允许 输入 的 字符 数 ， 并 计 
算 已 用 字 节 数 与 剩余 字 节 数 ， 代 码 如 下 
<SCRIPT language=JavaScript> 
var LastCount =0; 
function StatByte(Message,maxs,Used.Remain){ / 字 节 统计 
var ByteCount = 0; 
var StrValue = Message.value; 
var StrLength = Message.value length; 
Var maxsValue =maxs.value; 
if(LastCount != StrLength) { // 在 此 判断 ， 减 少 循环 次 数 
for (i=0;i<StrLength:i++){ 
ByteCount = (StrValue.charCodeAt(i)<=256)? ByteCount+ 1 :ByteCount+ 2: 
if(ByteCount>maxsValue) { 
Message.value = StrValue.substring(0.2); 
alert(" 留 言 内 容 最 多 不 能 超过 " +maxsValue+ " 个 字 节 ! \n 注意 ， 一 个 汉字 为 两 字 节 。"); 
ByteCount = maxsValue; 
break: 


} 


Used.value = ByteCount; 
Remain.value = maxsValue - ByteCount: 
LastCount = StrLength; 

} 

} 

</SCRIPT> 


(4) 修改 “意见 内 容 ” 文 本 域 的 代码 ， 在 onKeyDown 事件 和 onKeyUp 事件 中 调用 自 定义 的 JavaScript 函 
数 StatByte0)， 限 制 输入 的 最 多 字符 数 并 计算 已 用 字 节 数 和 剩余 字 节 数 ， 代 码 如 下 : 


<textarea name="suggestions" cols="30" rows="5" class="wenbenkuang" id="suggestions" 
onKeyDown="StatByte(this.form.suggestions.this.form.maxs.this.form.used.this.form.remain):" 
onKeyUp="StatByte(this.form.suggestions.this form. maxs.this.form.used.this.form.remain);"> 
</textarea> 


国 秘笈 心 法 
心 法 领悟 156: 字 节 数 的 计算 。 
在 计算 字 节 数 时 ， 需 要 判断 输入 的 字符 是 汉字 还 是 英文 字母 或 数字 ， 因 为 一 个 汉字 占 两 个 字 节 。 


力 实例 说 明 


在 网 页 中 ， 有 些 文本 框 中 的 信息 是 不 允许 浏览 者 进行 修改 的 ， 即 用 户 只 有 浏览 的 权限 而 没有 修改 的 权限 。 
此 功能 可 以 通过 设置 文本 框 的 只 读 属 性 来 实现 。 运 行 本 实例 ， 在 页 面 中 修改 库存 数量 时 ， 将 弹出 “此 文本 框 为 
只 读 属 性 ， 库 存 数量 不 能 修改 ! ! ”的 提示 框 ， 运 行 结果 如 图 3.12 所 示 。 


国 关键 技术 


本 实例 的 关键 是 文本 框 中 readonly 属性 的 运用 , 通过 它 可 设置 文本 框 的 只 读 属性 , 然后 通过 onfocus 事件 调 
用 JavaScript 脚本 ， 当 用 户 单 击 已 经 设置 为 只 读 属性 的 文本 框 时 ， 弹 出 一 个 提示 对 话 框 。 
使 用 readonly 属性 实现 只 读 的 代码 如 下 : 


<input id="0" class="0" type="text" readonly value="0100521041'/> 


” i ed i 


趣味 指数 : 妇女 太太 
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[0100521041 
牛奶 


国 [oo 
加 


图 3.12 设置 文本 框 的 只 读 属 性 
力 设计 过 程 
新 建 index.php 文件 。 编 写 表格 ， 在 表格 中 插入 <fom> 标 签 ， 编 写 文本 框 ， 设 置 文本 框 的 属性 为 readonly， 


商品 编号 ;<input id="o" class="o" type="text" readonly valuc=0100521041/><br> 

商品 名 称 ，<input id="o"type="text" value=" 酸 牛奶 " onfocus="this.value="" /><br> 

库存 数量 ，<input id="o" class="n"type="text" disabled="disabled" value="100 件 " /><br> 
管理 员工 : <input id="o"type="text" value="001" /> 

</form> 


图 秘笈 心 法 


心 法 领悟 157: 使 用 readonly 的 小 技巧 。 
在 使 用 readonly 时 ， 只 需 在 <input> 标 记 中 加 入 属性 名 称 即 可 。 


高 级 
起 味 指教: 宙 宙 机 


实例 158 


力 实例 说 明 


在 物流 管理 系统 中 ， 经 常 需要 计算 出 库 商品 的 金额 或 入 库 商 品 的 金额 ， 若 以 手工 计算 ， 比 较 麻烦 而 且 容易 
出 错 ， 如 果 在 程序 中 实现 自动 计算 金额 功能 ， 则 可 以 减少 许多 不 必要 的 麻烦 。 运行 本 实例 ,效果 如 图 3.13 所 示 。 


商品 六 5 
商品 单价 :| 


库存 数量 : [35 


人 人 金额 总 计 : 350 


3.13 ”自动 计算 金额 
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国 关键 技术 


本 实例 主要 通过 触发 表单 控件 的 blur 事件 ， 即 表单 控件 失去 焦点 时 ， 实 现 自动 计算 金额 。 实 现 此 功能 的 
JavaScript 代码 如 下 : 
$(".0").blur(functionO{ // 当 商品 单价 文本 框 失去 焦点 
var price = $(".0").valO: 
var num = $(".n").val|; 
var amount = price * num; 
、 S$(".e").val(amount):; 
图 设计 过 程 
编写 脚本 文件 并 命名 为 index.php。 引 入 CSS 样式 表 文 件 ， 导 入 JavaScript 脚本 。 编 写 表单 ， 当 商品 单价 失 
去 焦点 时 自动 计算 金额 ， 核 心 代码 如 下 : 


<form action=" method="post" name="form1"> 

商品 编号 ，<input id="o" type="text" readonly valuc= 酸牛奶 /><br> 
商品 单价 ;<input id="o" type="text"class="o" value="0.0"/><br> 

库存 数量 : <input id="o" class="n"type="text" value="35" readonly /><br> 
金额 总 计 : <input id="o" class="e"type="text" value="0.0" /> 

</form> 


秘笈 心 
心 法 领悟 158: 关于 blur 事件 。 


用 于 当 blur 事件 ( 即 失去 焦点 事件 ) 发 生 时 执行 JavaScript 代码 。 适 用 对 象 包括 Button、Checkbox、FileUpload、 
Layer、 Password、 Radio、Reset、Select、Submit、Text、Textarea 和 Window。 


BE 


图 实例 说 明 


在 实例 157 中 已 经 介绍 了 文本 框 只 读 属 性 的 相关 知识 ， 下 面 介 绍 一 种 与 只 读 属 性 类 似 的 属性 ， 即 设置 文本 
框 默认 值 。 运 行 本 实例 ， 效 果 如 图 3.14 所 示 ， 设 置 文本 框 的 默认 颜色 为 灰色 ， 当 在 用 户 名 中 输入 信息 时 动态 改 
变 文本 框 默 认 值 信息 。 


高 级 
趣味 指数 : 座机 廊 贾 


图 3.14 为 文本 框 设置 默认 值 


力 关键 技术 
本 实例 的 关键 是 通过 disabled 属性 设置 文本 框 的 默认 值 ， 然 后 通过 相关 事件 ,动态 改变 默认 值 文本 框 的 值 。 
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使 用 disabled 属性 设置 默认 值 的 代码 如 下 : 


<input id="0" class="0" type="text" disabled value="0100521041’/> 
图 设计 过 程 
(1) 新 建 index.php 文件 ， 引 入 CSS 样式 表 文 件 ， 编 写 表单 ， 代 码 如 下 : 


table width="350" border="0" class="p"> 
<u> 
<td width="100"> 用 户 名 : <ltd> 
<td align="left"><input class="m id="name"type="text" /></td> 
<ltr> 
<t> 
<td> 职 &nbsp:&nbsp: 位 : <ltd> 
<td align="left"><input class="m"type="text" id="type" disabled valuc= "自动 选取 "></td> 
<ltr> 
</table> 


(2) 定义 i 脚本 方法 ， 动 态 改变 文本 框 的 默认 值 ， 代 码 如 下 : 
S$("#name") keyup(function() 
Var name = $(" 2 0 
var manager = 
if(name — mt 
S$S("#type").val(" 经 理 "); 
Jelse{ 
S("#type").val(" 程 序 员 "); 


D; 
力 秘笈 心 法 
心 法 领悟 159: 关于 设置 文本 框 的 默认 值 。 


(1) 设置 文本 框 的 默认 值 与 设置 文本 框 的 只 读 属性 在 效果 上 是 相同 的 。 
(2) 在 使 用 disabled 时 ， 只 需 在 <input> 标 记 中 加 入 属性 名 称 即 可 。 


实例 160 趣味 指数 : 依依 依依 


力 实例 说 明 


form 表单 的 文本 框 在 默认 情况 下 不 够 美观 ， 使 用 默认 的 文本 框 样式 将 影响 网 站 的 视觉 效果 。 运 行 本 实例 ， 
效果 如 图 3.15 所 示 ， 利 用 CSS 代码 和 简单 的 JavaScript 代码 ， 使 文本 框 变 得 生动 、 有 特色 。 


图 3.15 设置 文本 框 样式 


PHP 开发 实例 大 全 (基础 卷 ) 


图 关键 技术 


本 实例 首先 为 文本 框 定义 CSS 样式 ， 然 后 通过 设置 鼠标 事件 调用 CSS 样式 ， 动 态 改变 文本 框 的 边框 颜色 。 
使 用 CSS 样式 的 代码 如 下 : 


mouse{ 
border:1px #EF0000 solid: 
background-color#FFCCFF: 


} 
使 用 JavaScript 定义 鼠标 事件 ， 代 码 如 下 : 
S$("#n").mouseover(function|O{ 
S$("#n").css( {border:"1px #0099FF solid",background:"white"}); 
S$("#n") -mouscout(fimctionO{ 
S("#n").css( {border:"1px red solid".background:"#FFCCFF"}): 
和 
DD; 
S$("#na") .mouseover(functionO{ 
S("#na").css({border:"1px #0099FF solid".background:"white"}): 
S$("#na").mouseout(function(): 
S("#na").css({border:"1px red solid".background:"#FFCCFF"}); 
D; 
和 


国 设计 过 程 
(1) 新 建 index php 文件 ， 建 立 网 页 架构 ， 编 写 form 表单 ， 其 关键 代码 如 下 : 


<table width="350" border="0" class="p"> 
<tr> 
<td width="100"> 用 户 名 :</td> 
<td align="left"><input type="text" class="mouse" id="n"/></td> 
<it> 
<t> 
<td> 密 &nbsp:&nbsp: 码 : <ltd> 
<td align="left"><input type="text" class="mouse" id="na" /></td> 


es 
(2) 引入 CSS 样式 和 JavaScript 脚本 ， 核 心 代码 见 关键 技术 。 
图 秘笈 心 法 


心 法 领悟 160: 引入 CSS 样式 。 
定义 CSS 样式 表 后 需要 引入 到 相关 脚本 文件 中 才能 起 到 作用 。 一 般 是 在 <meta> 标 签 下 ， 利 用 <link> 标 签 引 
入 。 以 本 实例 为 例 ， 代 码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/ine.css"/> 


图 实例 说 明 


文本 域 本 身 有 自 带 的 滚动 条 ， 用 户 可 以 通过 滚动 条 浏览 文本 域 中 的 所 有 内 容 ， 但 是 在 初始 情况 下 ， 用 户 
可 以 根据 需要 设置 文本 域 的 列 宽 ， 也 就 是 确定 文本 域 在 初始 情况 下 显示 多 少 内 容 。 运行 本 实例 ,效果 如 图 3.16 
所 示 。 


高 级 | 
趣味 指数 : 请 请 博朗 ， 


192 


第 3 章 Web 页 面 交 互 


图 3.16 文本 域 的 滚动 条 


图 关键 技术 
ps i JavaScript 代码 ， 动 态 改变 文本 框 的 rows 属性 。JavaScript 代码 如 下 : 


S$("#down").click(function()- 
S$("textarea").attr(" 本 "8"); 
S$("#up").click(functionO{ 
S("textarea").attr("rows","1"); 
D); 
看 设计 过 程 
(1) 新 建 index.php 文件 , 通过 <table> 标 签 建立 网 页 框架 , 输入 文本 域 代码 ， 引 入 CSS 样式 表 和 JavaScript 
脚本 ， 代 码 如 下 : 


<table width="600" height="600" border="0" align="center" background="pic/bgjpg"> 
<t> 
<td align="center"> 
<textarea cols="40"><?php echo $str:?></textarea><br><br> 
<input type="button" id='down' value='&nbsp; /> 
<input type="button" id='up' value='&nbsp: '/> 


(2) 编写 JavaScript 脚本 文件 ， 代 码 见 关键 技术 。 
国 秘笈 心 法 


心 法 领悟 161: 编写 JavaScript 代码 的 注意 事项 。 
编写 JavaScript 代码 时 ， 要 注意 JavaScript 代码 是 区 分 函数 大 小 写 的 。 


3.3 ”下拉 列表 的 应 用 


下 拉 列 表 是 一 种 最 节省 空间 的 数据 显示 方式 ， 正 常 状态 下 只 能 看 到 一 个 选项 ， 单 击 控制 按钮 后 ， 可 以 显示 
一 定数 量 的 选项 ， 如 果 超 出 这 个 数量 ， 会 自动 显示 滚动 条 ， 浏 览 者 可 以 通过 拖 动 滚动 条 来 查看 各 选项 。 


实 级 | 


力 实例 说 明 
在 进行 网 站 开发 的 过 程 中 ， 经 常会 用 到 相互 关联 的 菜单 。 例 如 ， 省 、 市 、 县 3 级 联动 或 者 省 、 市 2 级 联动 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
菜单 。 在 本 实例 中 将 讲解 如 何 实现 省 、 市 2 级 联动 菜单 ， 其 运行 效果 如 图 3.17 所 示 。 


图 3.17 省 、 市 级 联动 菜单 


力 关键 技术 


本 实例 通过 设置 change 事件 实现 联动 的 下 拉 列 表 ， 并 且 根 据 1 级 下 拉 列 表 传 递 的 不 同 参数 ， 显 示 不 同 的 2 
级 下 拉 列 表 信 息 。 实 现 这 些 功 能 的 JavaScript 代码 如 下 : 
S("#select1").change( function0 { 
var id = $("#select1").valO; 
iflid=— D{ 
S$.get(index.php’, null, fanction(data){ 

S$("span").emptyO; 
S$("span").append("<select><option> 长 春 </opton><option> 松 原 </opton><option> 通 辽 </opton></select>"); 


D; 
Jelse{ 
S$.get(index.php' null, function(data){ 
S("span").emptyO); 
$("span").append("<select><option> 大 连 </opton><option> 旅 顺 </opton><option> 钱 鱼 圈 </opton></select>"); 
D; 
} 
D; 


图 设计 过 程 
(1) 创建 脚本 文件 ， 引 入 CSS 样式 表 和 JavaScript 脚本 。 编 写 1 级 下 拉 列 表 ， 设置 <option> 标 签 属性 value 
的 值 ， 代 码 如 下 : 


<select id="select1"> 
<option value="" selected> 请 选择 </option> 
<option value="1"> 吉 林 </option> 
<option value="2"> 辽 宁 </option> 

</select> 


(2) 编写 JavaScript 代码 ， 当 选择 1 级 下 拉 列 表 项 时 ， 触 发 change 事件 ， 代 码 见 关键 技术 。 
力 秘笈 心 法 


心 法 领悟 162: JavaScript 脚本 语言 的 小 技巧 。 
如 果 在 JavaScript 脚本 中 出 现 长 语句 , 可 以 在 JavaScript 语句 的 最 后 加 上 字符 “\”, 使 一 条 长 语句 分 多 行 编写 。 


单 级 | 
图 实例 说 明 


实例 162 中 讲解 了 如 何 实现 2 级 联动 菜单 ， 下 面 将 讲解 如 何 实现 省 、 市 、 县 3 级 联动 菜单 。 运 行 本 实例 ， 
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效果 如 图 3.18 所 示 。 


图 3.18 省 、 市 、 县 级 联动 菜单 


力 关键 技术 


实现 省 、 市 、 县 3 级 联动 菜单 与 实现 省 、 市 2 级 联动 菜单 的 思路 大 致 相同 ， 但 是 需要 套用 多 层 的 if...else.… 
语句 实现 。 


力 设计 过 程 
(1) 创建 脚本 文件 ， 命 名 为 index.php。 创 建 form 表单 ， 编 写 下 拉 列 表 框 ， 定 义 2 级 联动 和 3 级 联动 的 下 
拉 列 表 选 项 ， 代 码 如 下 : 


<select id="select1"> 
<option value="" selected> 请 选择 </option> 
<option value="1"> 吉 林 </option> 
<option value="2"> 辽 宁 </option> 
</select> 
<span id='two'></span> 
<span id='three'></span> 
(2) 编写 JavaScript 脚本 文件 ， 当 触发 change 事件 时 ， 实 现 联动 效果 ， 代 码 如 下 : 
$("#select1").change( function() { 
var id = $("#select1").val|); 
iflid— D{ 
S$.get('index.php', null, function(data){ 
S$("#two").emptyO: 
$("#two").append("<select id='select2'><option> 请 选择 </opton><option value='1> 长 春 </opton><option value=2> 松 原 
</opton></select>"); 
S$("#select2").change( function0 { 
var page = $("#select2").valO; 
iflpage — D{ 
S$("#three").empty(): 
$("#three").append("<select><option> 双 阳 </opton><option> 农 安 </opton></select>"); 
jelse{ 
ifl(page — 2){ 
S("#three").emptyO: 
S$("#three").append("<select><option> 乾 安 </opton><option> 大 安 </opton></select>"); 


» 
D); 
D; 
jslse{ 

S$.get(index.php', null, function(data){ 
S$("#two").emptyO: 
S$("#two").append("<select id='select3'><option value="1> 大 连 </opton><option value='2 人 > 旅顺 </opton></select>"); 
S$("#select3").change( function() { 

var page = $("#select3").val|): 
ifl(page — D{ 
S$("#three").emptyO: 
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S$("#three").append("<select><option> 西 岗 </opton><option> 沙 河口 </opton></select>"): 


国 秘笈 心 ; 
心 法 领悟 163: 打造 优秀 的 3 级 联动 菜单 。 


本 实例 旨 在 讲述 实现 3 级 联动 菜单 的 原理 ， 在 实际 开发 中 是 不 建议 使 用 让 .else.…. 语 句 的 ， 因 为 这 样 的 多 层 
顽 套 方式 一 方面 使 程序 本 身 的 可 读 性 变 差 ， 而 且 还 有 可 能 不 利于 程序 员 编程 。 


要 联机 的 网 站 高 级 | 


趣味 指数 : 址 食 食 侠 | 


实例 164 


力 实例 说 明 


在 开发 网 站 程序 的 过 程 中 ， 多 数 网 站 都 设置 了 友情 链接 这 一 模块 ， 通 常情 况 下 ， 链 接 的 网 站 以 图 标 、 网 站 
名 或 地 址 的 形式 显示 在 页 面 中 ， 浏 览 者 可 通过 单 击 超 链 接 进入 所 要 访问 的 网 站 。 为 了 更 好 地 利用 页 面 ， 可 以 通 
过 下 拉 列 表 框 的 方法 来 创建 友情 链接 。 运 行 本 实例 ， 当 用 户 选 择 下 拉 列 表 框 中 所 要 联机 的 网 站 后 〈 如 图 3.19 所 
示 ) ， 单 击 GO 按钮 可 以 立即 链接 到 指定 的 网 站 。 


图 3.19 应 用 下 拉 列 表 框 选择 要 联机 的 网 站 


力 关键 技术 


本 实例 首先 将 文本 框 的 value 属性 值 定义 为 所 要 连接 的 人 P 地 址 ， 然 后 通过 设置 鼠标 的 单 击 事件 实现 链接 到 


指定 的 网 站 。JavaScript 代码 如 下 : 

S$(document) .ready(function(){ 
S$("#button").click(functionO{ 

var sel = $("#sel").valO: 

iflsel (=){ 

get(sel): 
Jelse{ 
alert( 请 选择 连接 内 容 '); 
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力 设计 过 程 
(1) 新 建 index php 文件 ， 创 建 下 拉 列表 框 ， 并 添加 下 拉 列 表 框 选项 值 ， 代 码 如 下 


<selectid-'sel> 

<option value="" > 友情 链接 </option> 
<option value="http://www.126.com">126 邮箱 </option> 
<option value="http://www.163.com">163 邮箱 </option> 
<option value="http://Wwww.4399.com">4399 小 游戏 </option> 

‘</select> 

<input id="button" class=button' type="submit" valuc="&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:" 户 

(2) 编写 JavaScript 脚本 文件 ， 当 单 击 GO 按钮 时 触发 事件 ， 完 成 页 面 的 跳 转 操作 。 


国 秘笈 心 法 


心 法 领悟 164: 使 用 CSS 样式 表 的 好 处 。 
利用 CSS 样式 可 以 大 量 减 少 网 页 代码 ， 其 原理 就 是 在 网 页 中 自 定义 样式 表 的 选择 符 ， 在 网 页 中 大 量 引 用 这 
些 选择 符 即 可 。 


趣味 指数 : 伍 食 三 食 


图 实例 说 明 


通常 ， 网 页 中 应 用 的 下 拉 列 表 框 的 选项 值 是 固定 不 变 的 ， 这 样 就 存在 一 些 弊病 ， 如 不 能 向 下 拉 列 表 框 中 添 
加 新 的 选项 值 ,如 果 能 编写 可 以 输入 字符 的 下 拉 列 表 框 , 就 方便 很 多 。 运 行 本 实例 , 在 部 门 的 下 拉 列 表 框 中 有 “ 生 
产 部 ”、“ 业 务 部 ”和 “技术 部 ”3 个 选项 ， 如 果 要 添加 一 个 “文化 部 ”， 直 接 在 下 拉 列 表 框 中 输入 “文化 部 ” 
即 可 ， 运 行 结 果 如 图 3.20 所 示 


很 方便 ! 


3.20 可 输入 字符 的 下 拉 菜 单 


力 关键 技术 


本 实例 的 开发 思路 如 下 : 网 页 中 下 拉 列 表 的 选项 值 是 固定 的 ， 要 实现 在 下 拉 列 表 框 中 输入 文字 ， 首 先 要 捕 
获 用 户 的 键盘 事件 ， 然 后 根据 键盘 输入 的 数据 动态 添加 下 拉 列 表 框 的 选项 ， 同 时 还 要 判断 用 户 按 下 的 是 
Backspace 键 还 是 Space 键 ， 如 果 是 Backspace 键 ， 则 需要 从 光标 指针 位 置 向 前 删除 一 个 字符 ， 如 果 是 Space 键 ， 
则 需要 在 光标 指针 位 置 添加 一 个 空格 字符 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
另外 ， 本 实例 还 利用 onKeyPress 和 onKeyUp 事件 调用 JavaScript 自 定义 函数 press(opb 和 up(opb。 


图 设计 过 程 


(1) 在 页 面 中 创建 部 门下 拉 列 表 框 ， 其 中 包括 “生产 部 ”、“ 业 务 部 ”和 “技术 部 ”3 个 选项 ， 代 码 如 下 : 
<form name="form1" method="post" action="index php" onKeyPress="press(3)" onKeyUp="up(3)"> 
<select name="userclass" size="1" id="userclass"> 
<option value=" 生 产 部 " selected> 生 产 部 </option> 
<option value=" 业 务 部 "> 业务 部 </option> 
<option value=" 技 术 部 "> 技术 部 </option> 
</select> 
</form> 


(2) 编写 键盘 按 下 事件 所 执行 的 JavaScript 自 定义 函数 press(opt)， 用 于 在 下 拉 列 表 框 中 添加 新 的 选项 ， 并 
将 用 户 输 入 的 信息 添加 到 下 拉 列 表 框 中 ， 设 置 该 选项 为 选中 项 。 
然后 编写 键盘 按 下 事件 所 执行 的 JavaScript 自 定义 函数 up(opt), 当 用 户 按 Backspace 键 时 , 将 已 经 写 到 下 拉 


列表 框 中 的 文字 逐个 删除 ， 当 用 户 按 Space 键 时 ， 在 下 拉 列 表 框 中 添加 一 个 空格 字符 ， 代 码 如 下 : 
function press(opt{ 
/lopt 表示 现 有 可 选项 的 数目 
forml.userclass.options[opt]j=new Option(ok=(forml.userclass.options[opt])? 
forml .userclass.options[opt] innerText+String fromCharCode(event.keyCode): 
String fromCharCode(event.keyCode).ok) 
forml.userclass.selectedIndex=opt; 
} 
function up(op){ 
/lopt 表示 现 有 可 选项 的 数目 
ifforml .userclass.options[opt]){ 
iflevent keyCode—8){ 
var str=forml.userclass.options[opt].innerText: 
var len=str.length; 
forml.userclass.options[opt] innerText=str.substring(0,len-1); 
if(forml .userclass.options[opt] innerText—" ")userclass.remove(2); 
} 
这 eventkeyCode 一 32){ 
forml.userclass.options[opt] innerTextt=" "; 
1 
} 
} 
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心 法 领悟 165: 使 用 JavaScript 代码 删除 输入 文字 的 注意 事项 。 
在 删除 输入 选项 中 的 文字 时 ， 如 果 删 除 到 最 后 一 个 字符 ， 则 将 该 选项 一 同 删除 ， 同 时 改变 下 拉 列 表 框 的 
选中 项 。 


实例 166 


趣味 指数 : 帘 丰 本 容 | 


力 实例 说 明 


在 注册 登录 模块 中 ,下拉 列 表 框 往往 被 应 用 在 选择 用 户 性 别 上 ， 如果 用 户 忘记 选择 此 下 拉 列 表 框 中 的 内 容 ， 
就 很 容易 把 注册 信息 弄 错 。 解 决 这 个 问题 的 方法 是 为 下 拉 列 表 框 设 置 默 认 值 ， 如 图 3.21 所 示 ， 当 没有 对 下 拉 列 
表 框 进行 操作 时 ， 将 弹出 提示 信息 。 
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图 3.21 设置 下 拉 列 表 框 的 默认 值 


图 关键 技术 


本 实例 首先 为 下 拉 列表 框 设置 默认 值 ， 然 后 通过 设置 按钮 的 单 击 事件 实现 当 用 户 单 击 “提交 ”按钮 时 ， 判 
断 下 拉 列 表 框 的 内 容 是 否 被 选择 。 


使 用 selected 属性 实现 设置 默认 值 的 代码 如 下 : 
<option sclected value="1"> 请 选择 性 别 </option> 


图 设计 过 程 
(1) 新 建 index.php 文件 ， 引 入 CSS 文件 和 JavaScript 脚本 ， 编 写 下 拉 列 表 框 ， 代 码 如 下 : 


sclect> 
<option selected value="1"> 请 选择 性 别 </option> 
<option > 男性 </option> 
<option > 女性 </option> 
/select> 
<input id="one" type="button" value="&enbsp:é&enbsp;&nbsp: Gnbsp; &nbsp:&enbsp:éenbsp:&enbsp:" /> 
(2) 编写 JavaScript 代码 ， 当 按钮 被 单 击 时 触发 事件 ， 其 代码 如 下 : 
S$(document) ready(functionO{ 
$("#one").click(functionO{ 
var value = $("select").val(); 
if(value — D{ 
alert(" 您 没有 选择 性 别 "); 


图 秘笈 心 法 
心 法 领悟 166: 关于 设置 下 拉 列 表 框 的 默认 值 。 
在 使 用 selected 时 ， 只 需 在 <option> 标 记 中 加 入 属性 名 称 即 可 ， 其 代码 如 下 : 


‘<option selected="selected"></option> 
a 浊 式 级 | 
力 实例 说 明 


对 页 面 的 美化 处 理 并 不 属于 程序 员 的 工作 范畴 ， 而 是 属于 前 台 美工 的 分 内 之 事 ， 但 是 像 这 种 美化 下 拉 列 表 
框 的 小 事情 ， 程 序 员 如 果 还 要 和 美工 去 协调 未 免 有 点 浪费 时 间 ， 所 以 学 习 一 些 基本 的 页 面 美 化 方法 还 是 很 有 必 
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要 的 。 运 行 本 实例 ， 效 果 如 图 3.22 所 示 。 


图 3.22 设置 下 拉 列 表 框 的 样式 


力 关键 技术 
本 实例 运用 CSS 样式 表 改变 下 拉 列 表 框 的 样式 ， 代 码 如 下 : 


select{ 
width:100px: 
font-family:" 楷 体 _GB2312"; 
font-size:14px; 
color-#FFFFFF; 
background-color:#000000; 
} 


力 设计 过 程 


(1) 创建 index.php 文件 ， 载 入 CSS 样式 ， 编 写 下 拉 列 表 框 ， 代 码 如 下 : 
<option selected value="1"> 请 选择 性 别 </option> 
<option > 男性 </option> 
<option > 女性 </option> 
</select> 


(2) 定义 CSS 样式 ， 代 码 如 关键 技术 中 所 示 。 
国 秘笈 心 法 


心 法 领悟 167: 关于 设置 下 拉 列 表 框 的 样式 。 
支持 下 拉 列 表 框 的 CSS 样式 很 少 ， 所 以 想 设置 更 多 的 样式 相对 来 说 会 很 麻烦 。 如 果 非 要 定义 一 个 漂亮 的 下 
拉 列 表 样式 ， 最 好 利用 JavaScript 代码 自行 编写 。 


实例 168 


国 实例 说 明 


实例 164 中 已 经 讲解 了 如 何 跳 转 到 链接 网 站 的 方法 ， 本 实例 与 实例 164 在 实现 思路 上 是 相同 的 ， 唯 一 不 同 
的 是 在 下 拉 列 表 框 里 通过 打开 新 窗口 实现 跳 转 。 运 行 本 实例 ， 效 果 如 图 3.23 所 示 。 
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施 步 票 。 帮 助 编程 者 提 


图 3.23 选择 链接 网 站 


图 关键 技术 


本 实例 实现 的 方法 是 定义 JavaScript 脚本 的 change 事件 ， 通 过 JavaScript 的 window.open() 方 法 ， 实 现 新 页 


面 的 跳 转 ， 代 码 如 下 : 
S$(document).ready(function(){ 
S("#sel").change(function|{ 

window.open($("#sel").val|); 
D); 
D; 


力 设计 过 程 


(1) 创建 脚本 文件 ， 建 立 网 页 框架 ， 引 入 CSS 样式 表 和 JavaScript 脚本 ， 编 写 下拉 列 表 ， 代 码 如 下 : 
<link type="text/css" rel="stylesheet" href="css/ine.css"/> 
<script type="textjavaseript" sre="../js/jquery-1.3.2.s"></script> 
<script type="textjavaseript" sre="js/in:js"></seript> 
<select id="sel" > 
<option> 友 情 链接 </option> 
<option value='http://www.126.com'>126 邮箱 </option> 
<option value='http://www.163.com'>163 邮箱 </option> 
<option value= http://www.4399.com'>4399 小 游戏 </option> 
</select> 


(2) 编写 JavaScript 脚本 文件 ， 当 发 生 change 事件 时 发 生 跳 转 。 
力 秘笈 心 法 


心 法 领悟 168: 关于 JavaScript。 
本 实例 主要 采用 JavaScript 语言 和 jQuery 框架 编写 , jQuery 框架 是 以 JavaScript 语言 编写 的 , 所 以 两 者 可 以 
混 编 。 


高 级 | 
趣味 指数 : 会 依依 会 


实例 169 


力 实例 说 明 


Tab 键 在 编写 Word 等 文档 时 是 经 常 被 用 到 的 。 在 网 页 的 文本 域 中 ， 按 Tab 键 是 进行 下 一 个 切换 项 的 指示 ， 
如 何在 文本 域 中 体现 Tab 键 呢 ? 本 实例 将 向 用 户 讲解 。 运 行 本 实例 ， 效 果 如 图 3.24 所 示 。 
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高 限 公司 是 国 


i 


图 3.24 文本 域 中 体现 Tab 键 


图 关键 技术 
本 实例 主要 是 通过 JavaScript 代码 定义 onkeydown 事件 实现 的 ， 代 码 如 下 : 


function editTabO{ 
var code, sel, tmp, r 
var tabs="" 
event.returnValue = false 
sel =event.srcElement.document.selection.createcRange() 
r=event.srcElement.createTextRange() 
switch (event. keyCode){ 
case (8): 
if(!(sel.getClientRects(.length > 1)){ 
event.returnValue = true 
retum 
} 
code =sel.text 
tmp = sel.duplicate() 
tmp.moveToPoint(r.getBoundingClientRect().left, scl.getClientRects|[0].top) 
sel.setEndPoint("startToStart", tmp) 
sel.text = sel.text.replace(/^\t/gm, "") 
code = code.replace(/^\t/gm. "").replace(/\r\n/g, mr 
rfindText(code) 
.select() 
break 
case (9): 
if (sel.getClientRects().length > 1){ 
code = sel.text 
tmp = sel.duplicate() 
tmp.moveToPoint(r.getBoundingClientRectO .left sel.getClientRectsO[0].top) 
sel.setEndPoint("startToStart", tmp) 
sel.text = "\t"+sel.text.replace(/\r\n/g, wet) 
code = code.replace(/\r\n/g. mt) 
rfindText(code) 
rselectO 
Yelse{ 
sel.text = "\t" 
selselectO 
} 
break 


case (13): 
tmp = sel.duplicate() 
tmp.moveToPoint(r.getBoundingClientRect().left. sel.getClientRectsO[0].top) 
tmp.setEndPoint("endToEnd", sel) 
for (var i=0; tmp.text.match(/^[\t]+/g) && i<tmp.text.match(/^[\t]+/g)[0].length: i++) tabs += "\t" 
sel.text = "\r\n"+tabs 
sel.select| 
break 
defanlt: 
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event.retumValue = true 
break 


} 
} 


设计 过 程 
(1) 创建 脚本 文件 ， 引 入 JavaScript 脚本 ， 编 写 文本 域 标签 ， 代 码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/inc.css"/> 
‘<script type="textjavascript" sre="js/in.js"></script> 
<textarea cols="30" name="text" rows="3" onkeydown="editTab()"></textarca> 


(2) 当 按 下 键盘 按键 时 触发 事件 ， 代 码 见 关键 技术 。 
图 秘笈 心 法 


心 法 领悟 169: JavaScript 脚本 的 引用 。 
本 实例 调用 JavaScript 中 的 editTab0 函 数 完 成 对 Tab 键 的 控制 ,在 页 面 中 引用 JavaScript 文件 的 方法 是 应 用 


<script> 标 签 ， 其 代码 如 下 : 
Es 


3.4 表单 元 素 的 动态 操作 


所 谓 动 态 操作 表单 元 素 是 指 页 面 中 的 表单 元 素 并 不 是 固定 不 变 的 ， 而 是 在 程序 执行 时 由 系统 根据 实际 情况 
自动 生成 。 这 里 将 通过 实际 的 例子 来 介绍 如 何 动态 生成 表单 元 素 。 


Eee 
图 实例 说 明 


在 开发 程序 的 过 程 中 ， 经 常 应 用 到 在 线 投票 模块 ， 其 使 用 非常 简单 ， 只 要 选中 一 个 单 选 按钮 或 者 多 个 复 选 
框 所 对 应 的 投票 主题 后 ， 单 击 “ 提 交 ” 按 钮 即 可 完成 投票 。 本 实例 将 介绍 投票 系统 的 操作 原理 ， 当 选中 一 个 投 
票 主题 之 后 ， 就 会 弹出 相应 的 投票 选区 ， 在 该 选区 中 可 以 添加 投票 并 可 以 看 到 投票 的 结果 ， 运 行 结果 如 图 3.25 
所 示 。 


如 果 在 编程 词典 中 没有 您 需要 的 录像 ， 讲 及 时 反 博 给 我 们 ， 我 们 全 力 安排 专 家 其 |" 
ee 


图 3.25 在 线 统计 
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图 关键 技术 
本 实例 主要 是 通过 文件 操作 和 正则 表达 式 函 数 实现 在 线 统计 程序 。 其 中 文件 操作 的 核心 代码 如 下 : 


Sfile = file get contents("info.txt): 
if(sfile —"™"){ 
Sopenn = fopen("info.txt",a); 
fwrite($openn,'a); 
fclose($openn); 
} 


ipreg_match(vSipSflej{ 
echo "<script>alert( 同 一 个 IP 地 址 ， 不 能 投票 两 次 ):</script>"; 


exit; 


Yelse{ 

这 !$open = fopen("info.txt",a') { 
print "文件 不 存在 ， 请 创建 "; 
exit; 

Jelse{ 
fwrite($open,$ip); 
felose($open); 

} 

E 


力 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 文件 和 JavaSeript 脚本 ， 编 写 单 选 按钮 ， 代 
码 如 下 : 


<form action="" method="post"> 
<tr> 
<td class="three"><input id="id" name="check" checked type="radio" value="1" /> 上 网 </td> 
<td><img sre="pic/logol.JPG" /><font color='red' size="-1">10 人 </font></td> 
<ltr> 
<tr> 
<td class= "three"><input id="id"name="check" type="radio" value="2" /> 去 娱乐 场所 </td> 
<td><img sre="pic/logo2.JPG" /><font color='red'size="-1">15 人 </font></td> 
<itr> 
<tr> 
<td class="three"><input id="id"name="check" type="radio" value="3" /> 带 着 女友 轿 街 <htd> 
<td><img sre="pic/logo3.JPG" /><font color='red'size="-1">20 人 </font></td> 
<t> 
<tr> 
<td class="three"><input id="id"name="check" type="radio" value="4" /> 睡觉 </td> 
<td><img sre="pic/logo4.JPG" /><font color='red'size="-1">5 人 </font></td> 
<ltr> 
</form> 


(2) 当 单 击 “ 确 定 ”按钮 时 ， 首 先 获 取 客户 端 IP 地 址 ， 然 后 将 数据 写 入 文本 文件 中 ， 最 后 根据 提交 的 值 
通过 switch 语句 进行 判断 并 给 出 提示 信息 ， 代 码 如 下 : 


<?php 
if($ POST[sub){ 
$ip =$_SERVER[REMOTE_ADDR]: // 取 得 客户 端 他 地 址 
Sfile = file_get_contents(info.txt); // 将 文件 内 容 读 取 到 字符 串 
if($file 一 ""){f /如 果 文 件 内 容 为 空 
Sopenn = fopen("info.txt",a); /条 开 info txt 文件 
fwrite($openn,'a’); // 向 文件 中 写 入 一 个 字符 
fclose($openn): /关闭 文件 
} 
if(preg_match("/$ip/",$file){ /匹配 字符 串 
echo "<script>alert(' 同 一 个 IP 地 址 ， 不 能 投票 两 次 ”);</script>"; 
exit /退出 
yelse{ 


if(!Sopen = fopen("info.txt"™,a) { 
print "文件 不 存在 ， 请 创建" 
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exit 
jslsef 
fwrite(Sopen.Sip): 
felose($open);: 
} 
} 
switch($_ POST[check) { /switch 选择 语句 
Case "2": 
echo "<script>alert(' 您 选择 去 娱乐 场所 "):</script>"; 
break 
case "3": 
echo "<scripf>alert( 您 选择 和 女友 逛街 ):</scripf>": 
break 
case "4": 


echo "<script>alert(' 您 选择 睡觉 );</script>"; 
break 


case "1": 
echo "<script>alert( 您 选择 上 网 ');</script>"; 
break; 

} 


} 
笈 心 法 
心 法 领悟 170， 关于 对 文件 的 操作 。 


文件 的 操作 对 于 所 有 学 习 PHP 这 门 语言 的 人 来 说 都 会 感到 头疼 ， 特 别 是 对 文件 高 级 操作 中 的 指针 的 理解 ， 
更 是 如 此 。 所 以 笔者 建议 ， 在 学 习 这 部 分 知识 时 ， 一 定 要 先 打 好 基础 ， 然 后 多 实践 、 多 思考 。 


POO 


高 级 


趣味 指教 : 址 广 三 三 


力 实例 说 明 


论坛 系统 中 的 会 员 有 不 同 的 级 别 ， 一 种 是 超级 会 员 ， 拥 有 对 论坛 的 管理 权限 ， 另 一 种 是 普通 会 员 ， 只 能 发 
布 和 回复 论坛 信息 。 因此 在 论坛 的 权限 设置 模块 中 就 需要 应 用 单 选 按钮 对 超级 会 员 和 普通 会 员 设置 不 同 的 权限 。 
在 本 实例 中 ， 选 中 “超级 用 户 ” 单 选 按钮 时 ， 其 下 方 将 列 出 网 站 的 所 有 管理 模块 ， 管 理 员 可 以 为 超级 会 员 设置 
管理 权限 ， 运 行 结 果 如 图 3.26 所 示 ; 选中 “普通 用 户 ” 单 选 按钮 ， 运 行 结 果 如 图 3.27 所 示 。 


如 果 在 妨 程 局 条 中 没有 您 需要 的 录像 ， 请 及 时 反 情 给 我 们 ， 我 们 全 力 安 撑 专 家 息 / 如 军 友 妨 径 汝 两 中 冯 有 您 需 委 的 好 煞 ， 语 及 时 反馈 俗 我 们 ， 我 们 全 力 安排 专家 担 / 
开发 视频 录像 ， 并 及 时 升级 到 坊 程 词典 录像 中 ， 开发 视频 录像 ， 并 及 时 升 弘 号 编 年 同 此 又 像 十 。 
= 
mn 
NM 


T 
BR 
NS 


图 3.26 超级 用 户 设置 3.27 普通 用 户 设置 
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图 关键 技术 


选中 单 选 按钮 后 显示 其 他 表单 元 素 的 功能 ， 主 要 利用 JavaScript 设置 表格 的 display 样式 来 实现 表格 的 显示 
和 隐藏 。 通 过 设置 表格 的 ID 属性 ， 可 以 实现 对 表格 的 整体 控制 ， 如 设置 表格 的 style〈 样 式 ) 属性。 通过 将 表 
格 的 display 样式 设置 为 none， 可 以 控制 表格 的 隐藏 ， 将 表格 的 display 样式 设置 为 block， 可 以 显示 表格 。 


图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <table> 标 签 编写 网 页 架构 ， 引 入 CSS 样式 表 和 JavaScript 脚本 ,编写 form 表单 ， 
代码 如 下 : 


<link type="text/ess" rel="stylesheet" href="css/in.css"/> 
<seript type="text/javaseript" sre="../js/jquery-1.3.2.js"></script> 
‘<script type="text/javascript" sre="js/in.js"></script> 
<table align="center"> 
<u> 
<td> 用 户 名 :</td> 
<td><input type="text"/></td> 
<lt> 
<u> 
<td> 密 &nbsp;&nbsp; 码 :</td> 
<td><input type="text"/></td> 
<i> 
<t> 
<td> 权 限 设置 </td> 
<td><input id="va" type="radio" name="ch" value="1" checked 放 超级 用 户 <input id="val" name="ch"type="radio" value="2" /> 普通 用 户 </td> 
</ltr> 
<tr> 
<td><table id="namel"><tr><td><input type="checkbox" /> 帖子 管理 </td></tr></table></td> 
<td><table id="name2"><tr><td><tr><td><input type="checkbox" /> 后 台 管理 </td></tr></table></td> 
<it> 
<t> 
<td><table id="name3"><tr><td><tr><td><input type="checkbox" /> 数 库 管 理 </td></tr></table></td> 
<td><table id="name4"><tr><td><tr><td><input type="checkbox" /> 公告 管理 </td></tr></table></td> 
<t> 
</table> 


(2) 编写 JavaScript 脚本 文件 ， 将 style 属性 动态 添加 到 复 选 框 的 表格 中 ， 控 制 表格 的 隐藏 和 显示 ， 代 码 


如 下 : 
S$(document) rcady(function0){ 
S("#va").click(functionO{ 
S("#name1").css("display","block"): 
$("#name2").css("display","block"); 
S$("#name3").css("display","block"): 
$("#name4").css("display", "block"): 


»): 
S$("#val").click(functionO{ 


S$("#name4").css("display"," 
了: 
D; 


国 秘笈 心 法 


心 法 领悟 171: 添加 CSS 属性 。 


利用 jQuery 框架 可 以 很 容易 地 将 属性 和 值 动态 地 添加 到 指定 标签 中 ， 语 法 格式 如 下 : 
S("class/id") .attr("key", "value"): 
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起 味 指教: 三 机 庚 | 


力 实例 说 明 


PHP 是 一 种 服务 器 端的 编程 语言 ， 顾 名 思 义 ， 在 需要 时 与 服务 器 进行 交互 并 且 处 理 信息 ， 但 是 很 多 时 候 ， 
用 户 希 望 在 与 服务 器 交互 之 前 就 完成 一 些 操作 , 这 个 时 候 客 户 端 脚本 语言 JavaScript 的 作用 就 体现 出 来 了 。 运行 
本 实例 ， 通 过 JavaScript 代码 实现 不 提交 表单 获取 单 选 按钮 的 值 ， 如 图 3.28 所 示 。 


3.28 不 提交 表单 获取 单 选 按钮 的 值 


图 关键 技术 


本 实例 主要 是 通过 JavaScript 代码 定义 click 事件 ,获取 单 选 按钮 的 值 ， 并 且 将 单 选 按钮 的 值 通过 <div> 标 签 
返回 到 页 面 中 ， 代 码 如 下 : 
S$(document) ready(function){ 
$(".n").mouseover(functionO{ 
$(".n").css({background:"#FFCCCC",border:"1px red solid"}); 
$(".n").mouseout(functionO){ 
S$(".n").css( {background:"white".border:"1px #00CCFF solid"}): 


DD; 
S$(".0").mouseover(functionO{ 
$(".0").css( {background:"#FFCCCC",border:"lpx red solid"}); 
$(".0") mouseout(finctionO{ 
S$(".0").css({background:"white",border:"1px #00CCFF solid"}); 


Dp: 
S$("#e").click(functionO{ 
S$("#nam") .css("display"."block"): 
var value = $("#e").val|: 
S$("#name").html(value): 
»D; 
$("#ee").click(functionO{ 
S$("#nam").css("display"."block"); 
var value = $("#ee").valO; 
S$("#name").html(value); 
D): 
D; 


力 设计 过 程 
(1) 创建 脚本 文件 ， 引 入 CSS 样式 和 JavaScript 脚本 文件 ， 创 建 用 户 登录 的 form 表单 ， 设 置 文本 框 和 单 
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选 按钮 元 素 ， 并 且 设 置 <div> 标 签 定义 标签 的 ID 值 ， 核 心 代码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/in.css"/> 
<script type="text/javascript" sre="../js/jquery-1.3.2.js"></script> 
<script type="text javascript" sre="js/injs"></script> 
<table align="center"> 
<tr> 
<td> 用 户 名 : </td> 
<td><input class="n" type="text" /></td> 
</t> 
<t> 
<td> 密 &nbsp:&nbsp: 码 : <ltd> 
<td><input class="0" type="text" /></td> 
<lt> 
<t> 
<td><input id="e" name="ch"type="radio" value=" 保 存 密码 " /> 保存 密码 </td> 
<td><input id="ee" name="ch"type="radio" value=" 隐 身 登 录 " /> 隐身 登录 </td> 
</t> 
<tr> 
<td id="nam"> 单 选 按钮 值 为 : </td> 
<td><div id="name"></div></td> 
<> 
</table> 


(2) 编写 JavaScript 脚本 文件 injs， 引 入 jQuery 库 文件 jquery-1.3.2.js。 
力 秘笈 心 法 


心 法 领悟 172: jQuery 中 的 click 事件 。 
当 单 击 标签 时 触发 此 事件 ， 语 法 格式 如 下 : 


S("class/id").click(fanctionO{...}): 


实例 173 趣味 指数 : 依依 疹 痕 


力 实例 说 明 


复 选 框 应 用 在 用 户 注册 系统 中 ， 如 个 人 爱好 选择 等 。 本 实例 所 讲述 的 3 个 操作 : 全 选 、 反 选 、 不 选 ， 只 是 
根据 实际 情况 ， 对 复 选 框 实现 的 快捷 操作 。 运 行 本 实例 ， 全 选 的 效果 如 图 3.29 所 示 。 


命 收 芯 本 站 ”加 设 为 首页 中 联系 我 们 


筷 程 司 丙 介绍 。 篇 程 司 奥 在 线 棱 务 


欢迎 光临 明日 科技 网 站 


| 会 员 信息 管理 
万 欧阳 PHP 部 门 缀 香 » 
隐 东方 JAVA 部 门 经 理 » 
万 夏侯 w 部 门 受理 » 
古 南宫 8B 部 门 受理 2 


技术 服务 热线 : 0431-84976981 34978962 
Copyright 回 www_aingrisoft_coa 如 1 Rights Reserved! 


图 3.29 实现 全 选 
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图 关键 技术 


复 选 框 的 全 选 、 反 选 和 不 选 主要 应 用 JavaScript 脚本 ， 通 过 自 定义 函数 完成 。 

(1) 在 通过 JavaScript 脚本 中 的 自 定义 函数 完成 复 选 框 的 全 选 、 反 选 和 不 选 功能 中 ， 应 用 的 第 1 个 方法 是 
getElementsByTagName， 获 取 指 定 标签 的 名 称 ， 返 回 值 为 一 个 包含 标签 信息 的 object。 

(2) 根据 getElementsByTagName 标签 返回 的 对 象 ， 判 断 标 签 类 型 〈type) 的 值 是 不 是 checkbox。 

(3) 当 标 签 类 型 type 的 值 为 checkbox 时 ， 为 标签 中 的 checked 赋值 。 当 checked 的 值 为 TRUE 时 ， 将 其 
赋值 为 FALSE; 当 checked 的 值 为 FALSE 时 ， 将 其 赋值 为 TRUE。 

(4) 在 页 面 中 通过 script 标签 调用 js 文件 夹 中 的 文件 ， 应 用 onClick 事件 调用 自 定义 函数 ， 完 成 全 选 、 反 
选 和 不 选 功能 的 实现 。 


设计 过 程 
(1) 创建 js 文件 夹 ， 编 写 regjs 脚本 文件 。 在 regjs 文件 中 ， 编 写 自 定义 函数 ， 实 现 全 选 、 反 选 和 不 选 功 
能 。regjs 文件 的 关键 代码 如 下 : 


function uncheckAll(form] ,status) { // 不 选 
var elements = form] .getElementsByTagName('input ); // 获 取 input 标签 
for(var i=0; i<elements.length; i++){ /根据 标签 的 长 度 执行 循环 
if(elements[i] type 一 "checkbox) { // 判 断 对 象 中 元 素 的 类 型 
if(elements[i].checked—true){ // 判 断 当 checked 的 值 为 TRUE 时 
clements[i].checked=false; /| 将 checked 赋值 为 FALSE 
1 
} 
， 
function checkAll(forml,status) { // 全 选 


var clements = forml .getElementsByTagName('input ): 
for(var i=0; i<elements.length; i++){ 
if(elements[i].type — 'checkbox’) { 
这 elements[i].checked 一 false){ 
clements[i].checked=true; 
} 
} 
} 


} 
function switchAll(form!l ,status) { /反选 
var elements = forml .getElementsByTagName('input ); 
for(var i=0: i<elements.length: i++){ 
这 elements[i] type — ‘checkbox){ 
ielements[i].checked 一 tmue)f 
clements[i].checked=false: 
Yelse if(elements[i].checked—false){ 
clements[i].checked=true; 
} 


} 
} 


(2) 创建 index.php 页 面 ， 输 出 会 员 信息 ， 并 添加 图 像 按钮 ， 通 过 onClick 事件 调用 JavaScript 自 定义 函数 
实现 全 选 、 反 选 、 不 选 和 删除 的 功能 ， 其 关键 代码 如 下 : 


<script language="javascript" sre="js/reg.js"></script> 
<form method="post" name="forml" id="form1" action="index ok.php"> 
<tr> 
<td width="62" align="center"><input name="conn id[]" type="checkbox" id-"conn id[]" value="1" /></td> 
<td width="242"> 欧 阳 </td> 
<td width="243">PHP</td> 
<td width="485"> 部 门 经 理 </td> 
<td width="485">29</td> 
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< 

<tr> 

<td colspan="S" align="center"><!-- 通 过 onClick 事件 调用 自 定义 函数 ， 执 行 相应 的 操作 --> 
<img sre="images/bg_19-20.jpe" onclick="checkAll(forml ,status)" width="62" height="25" /> 
<img sre="images/bg_14-14.jpg" onclick="switchAll(forml ,status)"” width="62" height="25" /> 
<img sre="images/bg_07-08.jpg" width="62" height="25" onclick="uncheckAll(forml.status)" /> 
<input type="image" name="imageFicld" sre="images/bg_14.jpg” /> 

<htd> 

<lt> 

</form> 
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心 法 领悟 173: 复 选 框 的 全 选 、 反 选 和 不 选 的 实现 思路 。 

实现 复 选 框 的 全 选 、 反 选 和 不 选 操作 主要 应 用 JavaScript 脚本 ， 通 过 JavaScript 脚本 中 的 自 定义 函 数 ， 判 断 
复 选 框 中 checked 的 值 。 全 选 就 是 将 checked 赋值 为 TRUE， 不 选 则 是 将 checked 赋值 为 FALSE， 而 反选 则 是 当 
checked 的 值 为 TRUE 时 ， 将 其 赋值 为 FALSE; 当 checked 的 值 为 FALSE 时 ， 将 其 赋值 为 TRUE。 


实例 说 明 


开发 在 线 论坛 系统 时 ， 在 回复 帖子 的 模块 中 ， 要 记录 是 谁 回复 了 哪 一 个 帖子 ， 即 要 把 这 个 回复 用 户 的 ID 同 
回复 帖子 的 内 容 一 起 保存 起 来 。 回 帖 的 内 容 是 从 文本 域 中 获取 的 ， 而 回帖 人 的 ID 则 是 通过 隐藏 域 进行 提交 的 ， 
不 需要 手动 填写 ， 如 图 3.30 所 示 。 


高 级 
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3.30 ”隐藏 域 提交 用 户 DD 


力 关键 技术 


本 实例 主要 应 用 表单 中 的 隐藏 域 来 实现 文件 值 的 提交 和 获取 。 
表单 中 隐藏 域 的 语法 格式 如 下 : 

<input type= "hidden" name="ID" value=""> 

参数 说 明 : 

type: 表单 的 类 型 ， 其 中 的 hidden 表示 隐藏 域 。 

name: 隐藏 域 的 名 称 ， 可 以 自己 定义 。 

value: 隐藏 域 的 值 ， 可 以 填写 隐藏 域 的 默认 值 。 
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国 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表单 ， 代 码 
如 下 : 


<link type="text/css" rel="stylesheet" href="css/in.css"/> 
<seript type="text/javaseript" sre=",./js/jquery-1.3.2js"></script> 
<seript type="text/javascript" sre="js/injs"></script> 
ie width op height="600px" backgroond-"picbeipe™> 
二 
<table align="center"> 


<t> 
<td> 回 帖 ，<input type="hidden" name="ID" value="1081" /></td> 
<> 


<t> 
<td> 标 题 : <input type="text” /></td> 
<ltr> 
<t> 
<td> 内 容 ，<textarea cols="30" rows="3"></textarea></td> 
<la> 
<tr> 
<td><input class="one" type="submit" name="sub" value="" /></td> 
</t> 
<tr><td id="name" style="display:none"> 
隐藏 域 值 为 ，<b id="b1"></b><br> 标 题 值 为 ，<b id="b2"></b><br> 内 容 值 为 <b id="b3"></b> 
<ltd></t> 
</table> 
<ltd> 
<ltr> 
</table> 


(2) 编写 JavaScript 脚本 ， 当 单 击 “ 回 帖 ” 按 钮 时 触发 事件 ， 代 码 如 下 : 
S$(document) ready(function(){ 
S(".one").click(functionO{ 
var vall = $("input:eq(0)").valO; 
var val2 = $("input:eq(1)").valO; 
Var val3 = $("textarea").val(); 
S$("#name").css("display","block"); 
$C"#b1").html(vall); 
$C"#b2").html(val2); 
$C"#b3"). html(val3); 

})): 

D; 


国 秘笈 心 法 


心 法 领悟 174: jQuery 中 使 用 $("").html0 方 法 的 注意 事项 。 
此 方法 是 取得 第 1 个 匹配 元 素 的 HIML 内 容 。 这 个 方法 不 能 用 于 XML 文档 ， 但 可 以 用 于 XHTML 文档 。 


实例 175 


趣味 指数 : 人 广 食 太 食 : 


力 实例 说 明 


在 很 多 网 站 的 主页 布局 中 ， 程 序 员 除了 在 导航 栏 中 布置 一 些 按钮 外 ， 在 网 页 的 主体 部 分 中 很 少 出 现 类 似 于 
提交 的 按钮 ， 这 样 做 的 主要 目的 并 不 是 因为 网 页 中 不 再 需要 按钮 ， 而 是 被 一 些 超 链接 或 者 图 像 域 跳 转 所 替代 。 
运行 本 实例 ， 当 单 击 图 片 时 实现 表单 提交 ， 如 图 3.31 所 示 。 
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国 像 注 花 代 提 交 按 钮 
村 是: | 贱 BRHF 


十 昕 了 件 有 限 公司 ， 生 一 下 

家 知名 企业 和 
内 容 : 大 人 
标题 ， 明 日 软件 内 容 ， 明 日 软件 有 限 公司 ， 是 一 
家 知名 企业 


图 3.31 图 像 域 蔡 代 提交 按钮 
图 关键 技术 


本 实例 主要 是 利用 JavaScript 代码 ， 通 过 单 击 事件 完成 数据 的 提交 操作 ， 其 关键 代码 如 下 : 
$(document)ready(function0O){ 


$("img").click(functionO{ 
var input = $("input").val(); 
Var textarea = $("textarea").val(); 
iflinput 一 ” || textarea — ""){ 
alert(" 文 本 框 为 空 "); 
jslse{ 
S$(".n").css("display","block"); 
S$("#i") html(input): 
S$("#t").html(textarea); 
D; 
D; 


图 设计 过 程 


(1) 创建 脚本 文件 ， 建 立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表单 ， 代 码 如 下 : 
<link type="text/css" rel="stylesheet" href="css/in.css"/> 
‘<script type="text/javascript" fisljquery-1.3.2js"></script> 
‘<script type="text/javascript" sre="js/in.js"></script> 
<table width="319" align="center"> 
<tr> 
<td width="296" class="oo"> 图 像 域 蔡 代 提交 按钮 </td> 
<ltr> 
<tr> 
<td> 标 题 ， <input type="text" /></td> 
<ltr> 
<tr> 


<td> 内 容 ，<textarea cols="20" rows="3"></textarea>&nbsp:&nbsp:<img sre="pic/img.gif" /></td> 
<ftr> 


> 
<td class="n"> 标 题 : <b id="i"></b> 内 容 : <b id="t*></b></td> 
<t> 
</table> 


(2) 编写 JavaScript 脚本 文件 js， 当 单 击 图 片 时 触发 事件 ， 代 码 如 关键 技术 所 示 。 
国 秘笈 心 法 
心 法 领悟 175: 图 像 域 的 使 用 。 


使 用 图 像 域 进 行 跳 转 和 提交 的 方式 有 很 多 。 例 如 嵌入 到 <a> 标 签 中 ， 进 行 客户 端 跳 转 ;或 者 应 用 在 form 表 
单 的 提交 、 重 置 按钮 中 。 灵 活 运 用 图 像 域 的 知识 会 使 程序 更 美观 。 
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| 


实例 176 趣味 指数 : 会 


力 实例 说 明 


跳 转 菜单 在 网 站 中 是 很 常见 的 ， 一 般 被 放置 在 靠近 头 部 的 位 置 ， 又 称 导 航 栏 。 下 面 就 讲解 如 何 实现 单 击 按 
钮 页 面 跳 转 的 效果 ， 如 图 3.32 所 示 。 


FANXING xs ex nn 1 


首页 | 注册 | 登录 
1 
四 SD RE py 
"mm 
口 标题 位 置 放置 处 1110 3320 和 
硬盘 联系 方式 
口 标题 位 置 放置 处 1110 3320 和 tr 了 
口 标题 位 置 放置 处 1110 3320 所 
a 硬盘 电子 图 书 
口 标题 位 置 放置 处 1110 3350 站 Wa 
口 标题 位 置 放 置 处 1110 3320 wa 
口 标题 位 置 放置 处 1110 3320 
口 标题 位 置 放置 处 1110 3320 
口 标题 位 置 放置 处 1110 3320 
共有 2 页 ,当前 是 第 1 页 [ee ee | 


服务 热线 : 0431-84978981 0431-84978982 Mtpywww mingrlsoftcom 


CopyrightBwww mingrisoft com All Fights Reservedl 


3.32” 跳 转 菜单 实现 页 面 跳 转 


力 关键 技术 


本 实例 主要 通过 <map> 定 义 跳 转 ， 代 码 如 下 : 

<map name="Map2" id="Map2"> 
<area shape="rect" coords="89,64,141.94" href="index.php?id=1" /> 
<area shape="rect" coords="168.64.229.94" href="index.php?id=2" /> 
<area shape="rect" coords="250,65.305.99" href="index.php?id=3" /> 
<area shape="rect" coords="328.63.388.97" href="index.php?id=4" /> 
<area shape="rect" coords="13.65.61.93" href="index.php" /> 

</map> 


图 设计 过 程 
(1) 创建 index.php 文件 ， 设 计 网 页 ， 通 过 <map> 定 义 页 面 跳 转 的 超 链 接 。 
(2) 编写 PHP 代码 ， 当 单 击 不 同 按钮 时 实现 跳 转 ， 代 码 如 下 : 
~ switch(s_GET[idD{ 
pie IPO 
Pm 


Case "2": 


echo "pic/log JPG"; 
break: 
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国 秘笈 心 法 
心 法 领悟 176: 如 何 取得 地 址 栏 参数 。 


以 本 实例 为 例子 ， 地 址 组 成 格式 如 下 所 示 ， 可 以 通过 $_GET 方式 取得 相应 的 参数 并 进行 操作 。 
http:// 地 址 /主页 .php? 参 数 & 参 数 


起 hp 高 级 


图 实例 说 明 


上 传 图 片 时 最 好 为 程序 设置 预览 功能 ， 防 止 用 户 意外 传 错 图 片 。 还 有 一 个 很 重要 的 模块 就 是 获取 图 片 的 地 
址 ， 方 便 用 户 网 站 的 推广 。 运 行 本 实例 ， 完 成 预览 图 片 和 获取 图 片 地 址 的 功能 ， 运 行 结果 如 图 3.33 所 示 。 


3.33 ”上 传 预 览 图 片 


力 关键 技术 


本 实例 通过 JavaScript 的 click 事件 ， 实 现 图 片 预 览 、 获 取 地 址 和 清除 上 传 文本 框 信息 的 功能 ， 其 核心 代码 
如 下 : 


S$(document) ready(fanction){ 
S$("#two").click(functionO{ // 单 击 预览 图 片 
Var value = $("#one").val(): // 取 得 上 传 地 址 
这 value 一 ”){f / 漳 断 地 址 是 否 为 空 
alert(" 地 址 为 空 "); 
jelsef 
S$(".n").append("<img id- five sre="+valuet+">"); // 显 示 图 片 
S("#two").click(fanctionO{ 
S$(".n").emptyO; 


S$(".n").append("<img id=five' sre="+valuet+">"): 


3 
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D; 
} 


Dp: 
S$("ihree") .click(functionO{ // 显 示 图 片 地 址 
var value = $("#one").val(); 
if(value — ""){ 
alert(" 地 址 为 空 "): 
Jelse{ 
alert(value): 
} 
D; 
S$("#four").click(functionO{ // 清 除 文本 框 信息 
$(".e").emptyO): 


SC ppend( np clos one ene type fie 
D): 
D; 


力 设计 过 程 


(1) 新 建 index.php 文件 ， 引 入 CSS 样式 、injs 文件 以 及 jQuery 库 文件 jquery-1.3.2js。 创 建 form 表单 ， 


设置 文件 域 属性 ， 添 加 预览 图 片 、 图 片 地 址 和 清除 的 按钮 代码 如 下 : 
<table width="600" height="450" align="center" background="pic/bgjjpg"> 
0 align="center"><div class="n"></div> 
<table align="center"> 
<tr> 


"><input class="one" id="one" type="file"></span> 
<input class="one" id="two" type=button value=" 预 览 图 片 "> 
<input class="one" id="three" type=button value=" 图 片 地 址 "> 
<input class="one" id="four" type=button value=" 清 除 " > 


</span> 
<itd> 
</tr> 
</table> 
<ltd> 
<t> 
</table> 


(2) 编写 JavaScript 脚本 文件 injs， 代 码 见 关 键 技 术 。 
图 秘笈 心 法 


心 法 领悟 177: jQuery 框架 中 的 empty0 方 法 。 

empty0 方 法 : 删除 匹配 的 元 素 集 合 中 所 有 的 子 节点 ， 语 法 格式 如 下 : 
SCclass/id) .emptyO: 

参数 说 明 : 

class/id， 表 示 类 名 或 ID 名 称 。 


实例 178 


国 实例 说 明 


由 于 CSS 样式 对 下 拉 列 表 框 的 定义 很 少 , 以 至 于 想 要 修改 下 拉 列 表 框 的 样 
式 变 得 很 复杂 。 本 实例 将 讲解 如 何 去 掉 下 拉 列 表 框 的 边框 ， 如 图 3.34 所 示 。 


趣味 指数 : 宽广 食 食 


PHP 到 
[PHP 
ASP 


图 3.34 ”去掉 下 拉 列 表 框 的 边框 
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图 关键 技术 


本 实例 的 关键 点 是 严格 定义 CSS 样式 ， 代 码 如 下 : 
<div style="position: absolute: left: 10px: top: 10px: width: 115px: height: 20px: =clip:rect(2 114 20 2):"> 


图 设计 过 程 
创建 index.php 文件 ， 利 用 <table> 标 签 编写 表格 边框 。 编 辑 CSS 样式 ， 通 过 CSS 样式 去 掉 下 拉 列 表 框 的 边 
框 ， 代 码 如 下 : 


<table width="200px" height="100px" border="1" bordercolor="#0099FF" cellspacing="0"><tr><td> 
<div style="position: absolute; left: 10px: top: 10px; width: 115px: height: 20px: =clip:rect(2 114 20 2):"> 
<select> 
<option >PHP</option> 
<option >ASP</option> 
<option >JSP</option> 
</select> 
<ldiv> 
</td></tr></table> 


图 秘笈 心 ; 


心 法 领悟 178: CSS 的 效果 。 
像 上 面 这 样 较 为 生僻 的 代码 ， 其 实 笔者 也 不 能 够 完全 “吃透 ”， 但 是 没关系 ， 因 为 我 们 所 从 事 的 是 后 台 的 
开发 ， 前 台 的 东西 了 解 一 下 即 可 。 


实例 179 趣味 指数 : 妇女 


力 实例 说 明 


表单 可 以 添加 属性 并 且 与 客户 端 脚本 JavaScript 交互 ， 如 JavaScript 的 click、change 事件 等 。 运 行 本 实例 ， 
当 单 击 文本 框 时 弹出 提示 信息 ， 如 图 3.35 所 示 。 


如 果 在 编程 词 红 中 没有 您 需要 的 录像 ， 请 及 时 反 饥 给 我 们 ， 我 们 全 力 安排 专家 钉 / 
开发 视频 录 合 ， 并 及 时 升级 到 编程 词 红 录 创 中 。 


3.35 弹出 对 话 框 


力 关键 技术 
本 实例 主要 是 通过 JavaScript 代码 定义 单 击 事件 ， 核 心 代码 如 下 : 
S(document) ready(functionO{ 
SC"#o").click (fanctionO{ 


alert(" 文 本 框 被 单 击 "): 
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D; 
D; 


力 设计 过 程 


创建 index.php 文件 ， 引 入 CSS 样式 、JavaScript 脚本 文件 injs 和 jQuery 库 文件 jquery-1.3.2.js。 创 建 form 


<td> 用 户 名 : </td> 
<td><input id="0" type="text" /></td> 
<t> 
<t> 
<td> 密 &nbsp&nbsp: 码 : <ltd> 
<td><input id="o" type="text" onclick="alert(' 密 码 框 被 单 击 )"/></td> 
</t> 
</table> 


心 法 领悟 179: 定义 JavaScript 事件 。 


如 果 用 户 想 利用 JavaScript 本 身 的 方法 定义 事件 , 需要 在 表单 中 进行 , 代码 格式 如 实例 180 所 示 。 如果 是 利 


用 jQuery 框架 定义 事件 ， 只 需要 在 标签 中 定义 ID 或 者 类 即 可 。 
<input id="o"type="text" onlick=alert( 密码 框 被 单 击 J" 


实例 180 


高 级 | 
趣味 指数 : 去 去 去 去 | 


力 实例 说 明 
灵巧 的 CSS 是 所 有 Web 开发 者 追 氛 的 对 象 ， 其 主要 作用 是 通过 简单 的 代码 美化 页 面 ， 页 面 美化 用 CSS 基 

本 都 可 以 实现 。 本 实例 主要 讲解 通过 定义 CSS 样式 对 输入 单元 的 文字 进行 设置 ， 如 图 3.36 所 示 。 

上] 


用 户 名 : |asd 
客 码 : |asd 


图 3.36 动态 改变 文字 颜色 


图 关键 技术 
本 实例 的 关键 点 是 定义 CSS 样式 ， 通 过 JavaSeript 代码 动态 地 改变 文本 框 的 颜色 。JavaScript 代码 如 下 


<script type="text/javascript" language="javascript"> 


S$(document) ready(fanctionO{ 
S$("select").change(functionO{ 
var value = $("select").val(); 
iflvalue —"™"){ 
alert(" 请 选择 样式 颜色 "); 
Jelse{ 
S$("input:lt(2)").css("color",value); 
入 
六: 
</script> 
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力 设计 过 程 


(1) 创建 index.php 文件 ， 利 用 CSS 样式 定义 一 个 无 边框 的 下 拉 列 表 框 ， 代 码 如 下 : 
<div style="position: absolute; left: 10px: top: 10px: width: 115px; height: 20px: -clip:rect(2 114 20 2):"> 
<select> 
<option value=""> 样 式 颜色 </option> 
<option value="red">red</option> 
<option value="blue">blue</option> 
<option value="yellow">yellow</option> 
‘</select> 
</div> 
(2) 编写 文本 框 和 密码 框 ， 代 码 如 下 : 
<div style="font-family:' 楷 体 _GB2312'; font-size:16px:"> 
用 户 名 : <input type="text" /><br> 
密 &nbsp;&nbsp; 码 : <input type="text" /> 
<div> 


(3) 编写 JavaSeript 脚本 文件 njs， 动 态 改变 文本 框 输入 单元 颜色 ， 代 码 见 关键 技术 。 
国 秘笈 心 法 


心 法 领悟 180; jQuery 中 匹配 所 有 小 于 给 定 索引 值 的 元 素 。 
例如 ，$("tr:It(2)") 表 示 匹 配 <t> 标 签 中 小 于 索引 值 2 的 元 素 。 


高 级 


趣味 指数 : 女友 二 让 | 


实例 181 


实例 说 明 
在 创建 表单 中 的 文本 框 等 内 容 时 ， 往 往 会 给 文本 框 设 定 初始 值 ， 这 些 初始 值 需要 用 户 自行 手动 删除 。 为 了 


方便 用 户 ， 节 省 操作 时 间 ， 可 以 通过 设置 JavaScript 事件 ， 实 现 直接 删除 文本 框 中 初始 值 的 功能 。 运 行 本 实例 ， 
效果 如 图 3.37 所 示 。 


如 果 在 编程 词 弥 中 没有 您 需要 的 录像 ， 请 及 时 反 钱包 我 们 ， 我 们 全 力 安 徘 专家 制 | 
天 发 视频 好 全 ， 并 及 时 升级 到 妨 香 词典 录像 中 。 


3.37 表单 输入 单元 单 击 删除 


图 关键 技术 


第 3 章 Web 页 面 交互 
alert( 清 除 文本 框 信息 ): 


S(vtcxtarcan) click(function0{f 
Sthisjattr(valuen 


D: 

D; 
力 设计 过 程 

创建 index.php 文件 ， 引 入 CSS 样式 、JavaScript 脚本 文件 injs 和 jQuery 库 文件 jquery-1.3.2.js。 编 写 表单 
信息 ， 代 码 如 下 : 


<table align="center"> 
<t> 


<td> 标 题 : </td> 
<td><input type="text" value=" 请 输入 标题 " /></td> 
<lt> 
<tr> 
<td> 内 容 : </td> 
<td><textarea cols="23" rows="3"> 请 输入 内 容 </textarea></td> 
</tr> 
<htable> 


图 秘笈 心 法 


心 法 领悟 181， 如 何 简单 实现 本 实例 功能 。 
本 实例 是 采用 jQuery 框架 实现 的 ， 书 写 代 码 较 多 ， 还 有 一 种 简便 方法 是 在 表单 中 直接 定义 onFocus 事件 ， 
代码 如 下 : 


<input type='text name='te' value=' 请 输入 内 容 ' onFocus="this.value=""> 


高 级 
趣味 指数 : 容 机 全 贾 


实例 说 明 


很 多 网 站 中 往往 有 一 些小 的 技巧 ， 例 如 ， 在 文本 域 中 输入 内 容 时 ， 通 过 下 拉 列 表 框 动态 地 将 文字 插入 文本 
域 中 。 下 面向 用 户 讲述 这 一 功能 。 运 行 本 实例 ， 效 果 如 图 3.38 所 示 。 


如 果 在 编程 词 织 中 没有 您 需要 的 录像 ， 请 及 时 反馈 论 我 们 ， 我 们 全 力 安排 专家 岸 | 
开发 视频 录像 ， 并 及 时 升级 到 编程 词典 录像 中 。 


图 3.38 表单 文本 输入 的 移动 选择 


力 关键 技术 
本 实例 通过 JavaScript 脚本 中 的 change 事件 ， 实 现 动态 插入 信息 ， 其 核心 代码 如 下 : 
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S$(document) ready(functionO{ 
S$("textarea").select(); /选择 下 拉 列 表 框 
S$("select").change(functionO{ // 定 义 事件 
var value = $(this).val(); /获取 value 值 
var va = $("textarea").val(); /获取 文本 域 的 值 
这 va 一 "请 输入 内 容 "){ 
S$("textarea").html(value); // 输 出 文本 域 的 值 
Jelse{ 
S$("textarea").html(vatvalue); // 为 文本 域 赋值 
D: 
D; 
图 设计 过 程 


(1) 创建 index.php 文件 ， 引 入 CSS 样式 和 JavaScript 脚本 文件 injs， 以 及 jQuery 库 ， 创 建 下 拉 列 表 框 和 
文本 域 ， 代 码 如 下 : 


<table align="center"> 
<t> 
<td><select name="select"> 
<option value=" 谢 谢 "> 谢谢 </option> 
<option value=" 不 客气 "> 不 客气 </option> 
<option value=" 有 空 常 来 玩 "> 有 空 常 来 玩 </option> 
<option value=" 再 见 "> 再 见 </option> 
</select></td> 
<itr> 
<b> 
<td><textarea cols="20" rows="3"> 请 输入 内 容 </textarea></td> 
<it> 
</table> 


(2) 编写 JavaScript 脚本 文件 injs， 代 码 见 关键 技术 。 
力 秘笈 心 法 
心 法 领悟 182: 如 何 利用 jQuery 实现 文本 框 内 容 全 选 。 


实现 文本 框 内 容 全 选 与 单 击 文本 框 清除 所 有 信息 所 达到 的 效果 大 同 小 异 ， 其 实现 代码 如 下 
S$("textarea").select(); 


ee i 有 | 
趣味 指数 : 容 窒 页 让 | 
看 实例 说 明 


在 腾讯 的 QQ 系统 中 ， 可 以 通过 单 击 头像 实现 更 换 新 头像 的 功能 。 其 实 这 个 功能 相对 来 说 是 比较 简单 的 。 
运行 本 实例 ， 通 过 下 拉 列 表 框 实现 头像 的 选择 ， 如 图 3.39 所 示 。 


图 3.39 选择 头像 
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图 关键 技术 


本 实例 通过 JavaScript 的 change 事件 和 实例 162 中 的 2 级 联动 菜单 实现 ， 其 核心 代码 如 下 : 
S$(document) ready(functionO){ 
S$("select").change(functionO{ 
var value = $(this).val(); 
这 value 一 "){ 
alert(" 请 选择 性 别 "); 
Jelse{ 
iflvalue — "nan"){ 
S("#0").empty(); 
S$("#o").append("<select id-'onc><option valuc=pic/1jpg> 头 像 1</option><option value='pic/2.jpg> 头 像 2</option><option 
value='pic/3.jpg> 头 像 3</option><option value='pic/4.jpg> 头 像 4</option><option value='pic/9.jpg> 头 像 5</option></select>"); 
S("#n").empty(0); 
S("#n").append("<img sre=pic/1 jpg>"); 
S$("#one").change(functionO{ 
var va = $(this).val(); 
S$("#n").emptyO; 
S$("#n").append("<img sre="+vat">"); 
ba 
jelse{ 
S$("#o").emptyO; 
$("#o").append("<select id-'one><option value='pic/5.jpg> 头 像 1</option><option value='pic/6.jpg> 头 像 2</option><option 


value=pic/7jpg> 头 像 3</option><option value='pic/8.jpg> 头 像 4</option><option value= pic/10jpg> 头 像 5</option></select>"); 
$ empty(): 
和 .append("<img sre='pic/$.jpg>"); 
S$("#one").change(function() { 
var va = $(this).val(): 
S("#n").emptyO); 


S("#n").append("<img sre="+vat">"); 
D; 


} 
外 
»); 


图 设计 过 程 
(1) 创建 index.php 文件 ， 引 入 CSS 样式 和 JavaScript 脚本 文件 injs， 以 及 jQuery 库 ， 编 写 下 拉 列 表 和 标 
签 ， 代 码 如 下 : 


<table align="center"> 
<tr> 
<td> 
<select name="select"> 
<option value=""> 请 选择 性 别 </option> 
<option value="nan"> 男 性 </option> 
<option value="nv"> 女 性 </option> 
‘</select> 
<div id="0"></div><div id="n"></div> 
<ltd> 
<ltr> 
</table> 


(2) 编写 JavaScript 脚本 文件 injs， 代 码 见 关键 技术 。 
力 秘笈 心 法 


心 法 领悟 183: jQuery 中 的 this 关键 字 。 
jQuery 中 的 this 关键 字 与 其 他 编程 语言 大 致 相同 ， 此 关键 字 表示 当前 方法 体 的 类 名 称 或 者 ID 和 标签 , 书写 
格式 如 下 : 


varva=Sdthis)val0: 
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3.5 ”CSS+DIV 页 面 布局 


CSS+DIV 是 一 种 网 站 的 标准 或 称 面向 Web 的 标准 ) 中 常用 术语 之 一 ， 通 常 是 为 了 说 明 与 HTML 页 面 中 
的 表格 〈table) 定位 技术 的 区 别 ， 或 者 是 因为 HTML 网 站 设计 标准 中 不 能 使 用 表格 定位 技术 ,而 采用 CSS+DIV 
方式 实现 的 各 种 定位 。 


高 级 
起 叶 指数 砍 克 克 友 


实例 184 


图 实例 说 明 


对 于 一 个 页 面 风格 清新 自然 的 网 站 来 说 , 如 果 打开 的 窗口 带 有 不 适合 页 面 风格 的 灰色 边框 及 死板 的 标题 栏 ， 
不 但 不 能 体现 其 个 性 化 ， 而 且 势 必 会 影响 网 站 的 整体 效果 。 本 实例 介绍 一 种 应 用 CSS+DIV 实现 的 无 边框 窗口 。 
运行 本 实例 ， 单 击 “ 用 户 登 录 ” 超 链接 ， 即 可 打开 无 边框 的 用 户 登 录 窗 口 ， 如 图 3.40 所 示 。 


3.40 无 边框 窗口 


力 关键 技术 


本 实例 通过 CSS+DIV 排版 定位 技术 ， 将 表格 放置 在 指定 位 置 ，CSS 代码 如 下 : 


60 


Se ilbaed -ipg): 
#NOborder{ 
clear:left; 


float:right: 
position:absolute; 
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margin-right:10px; 
width:200px; 
height:100px; 
margin:auto; 

} 

#border{ 
width:auto: 
height:100px: 

了 


margin: 
width:80px; 
height:20px: 
} 


利用 JavaScript 代码 实现 表格 的 显示 或 隐藏 ，JavaScript 代码 如 下 : 
S$(document) ready(function(){ 
$("a").click(functionO{ 

S$("table").css("display", "block");: 


D); 

S$("#two").click(functionO{ 
S$("table").css("display". "none"); 

D); 

D; 


图 设计 过 程 
(1) 创建 index.php 文件 ， 载 入 CSS 样式 文件 和 JavaScript 脚本 文件 ， 通 过 <div> 标 签 对 网 页 进行 布局 ， 编 
写 无 边框 表格 ， 代 码 如 下 : 


<link type="text/css" rel="stylesheet" href="css/in.css"/> 
‘<script type="text/javascript" sre: sljquery-1.3.2.s"></script> 
‘<script type="text/javascript" sre="js/in.js"></script> 


<a href="#"> 用 户 登录 </a> 
</div> 
</div> 
<div id="NOborder"> 
<table border="1" bordercolor="#999999" cellspacing="0"><tr><td> 
<table> 
<tr> 
<td> 一 用 户 登录 一 </td> 
<itr> 
<u> 
<td> 用 户 名 ;<input type="text" size="10"/></td> 
<ltr> 
<tr> 
<td> 密 &nbsp:&nbsp; 码 : <input type="text" size="10" /></td> 
<t> 
<t> 
<td><input id="one" value="" type="button" /><input id="two” value="" type="button" /></td> 


(2) 编写 CSS 样式 文件 in.css 和 JavaScript 脚本 文件 injs， 代 码 见 关键 技术 。 
力 秘笈 心 法 
心 法 领悟 184: CSS 中 position 关键 字 的 使 用 。 
position 关键 字 用 于 检索 对 象 的 定位 方式 ， 其 属性 值 如 下 : 
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static: 无 特殊 定位 ， 对 象 遵循 HTML 定位 规则 。 

absolute: 将 对 象 从 文档 流 中 拖 出 , 使 用 left、right、top、bottom 等 属性 进行 绝对 定位 , 而 其 层 肢 通过 z-index 
属性 定义 。 此 时 对 象 不 具有 边 距 ， 但 仍 有 补 白 和 边框 。 

relative: 对 象 不 可 层 合 ， 但 将 依据 left、right、top、bottom 等 属性 在 正常 文档 流 中 偏 移 位 置 。 

fixed: IE 5.5 及 NS 6 尚 不 支持 此 属性 。 


力 实例 说 明 


表格 在 Web 开发 中 很 常见 ， 很 多 程序 员 都 喜欢 利用 表格 对 自己 数据 库 中 的 信息 进行 格式 输出 。 但 是 表格 在 
默认 情况 下 ， 无 论 从 色调 还 是 格式 上 都 不 是 很 理想 ， 这 就 需要 程序 员 利 用 CSS 的 知识 对 其 样式 进行 设置 。 运 行 
本 实例 ， 效 果 如 图 3.41 所 示 。 


2010-08-12 
2010-08-23 
2010-07-06 


图 3.41 设置 表格 样式 


力 关键 技术 
本 实例 利用 CSS 样式 ， 对 表格 的 边框 、 背 景色 等 进行 设置 ， 核 心 代码 如 下 : 
body{ 


margin-top:150px; 
} 


如 of 
margin-left:150px; 


} 

table.select{ 
font-family:" 楷 体 _GB2312"; 
font-size:16px: 


} 


table{ 
background:#32ACEF: 
td{ 

text-align:center; 

} 


.one{ 
background:#FFFFFF: 
} 


四 设计 过 程 


<img sre="pic/bannerjpg” /> 
</div> 
<divid="e"> 
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<table width="575" border="1" bordercolor-"#7DDSFA" cellspacing="0"><tr><td> 
<table width="575px"><tr> 
<td> 用 户 ID</td> 
<td> 用 户 名 <htd> 
<td> 密 码 </td> 
<td> 操 作 时 间 </td> 
<ltr> 
<tr class="one"> 
<td>001</td> 
<td>ym</td> 
<td>***#</td> 
<td>2010-08-12</td> 
<lt> 
<tr class="one"> 
<td>002</td> 
< td> 
<td>***</td> 
<td>2010-08-23</td> 


<td>2010-07-06</td> 
</t> 
</table></td></tr></table> 


(2) 编写 CSS 样式 ， 代 码 见 关键 技术 。 
力 秘笈 心 法 


心 法 领悟 185: 使 用 CSS 中 margin 关键 字 的 注意 事项 。 

(1) margin 关键 字 主要 用 于 检索 和 设置 对 象 四 边 的 外 沿边 距 ， 此 关键 字 根据 传 入 参数 的 不 同 ， 性 能 也 不 相 
同 。 如 果 提 供 全 部 的 4 个 参数 值 ， 将 按 上 、 右 、 下 和 左 的 顺序 作用 于 四 边 ， 如 果 只 提供 1 个 参数 ， 将 用 于 全 部 
的 四 边 ， 如 果 提 供 2 个 参数 ， 第 1 个 用 于 上 和 下 ， 第 2 个 用 于 左 和 右 ， 如果 提供 3 个 参数 ， 第 1 个 用 于 上 ， 第 
2 个 用 于 左 和 右 ， 第 3 个 用 于 下 。 

(2) 内 联 对 象 要 使 用 该 属性 ， 必 须 先 设 定 对 象 的 height 或 width 属性 ， 或 者 设 定 position 属性 为 absolute。 
在 IE 4+ 中 ，margin 属性 不 可 用 于 td 和 人 对 象 。 

(3) 外 延边 距 始终 透明 。 


5 高 级 
an | Bee 


力 实例 说 明 


CSS 之 所 以 受到 很 多 Web 设计 者 的 追捧 ， 是 因为 它 几乎 可 以 实现 所 有 的 基础 美化 功能 ， 图 片 当然 也 不 例 
外 。 运 行 本 实例 ， 应 用 CSS 样式 实现 图 片 向 左 和 向 右 浮动 、 为 图 片 添加 边框 的 功能 ， 运 行 结果 如 图 3.42 所 示 。 


他 ， 劣 人 都 喜欢 他 ， 他 的 名 字 叫 做 阿 几 提 。 


3.42 设置 图 片 的 样式 
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图 关键 技术 


本 实例 主要 通过 JavaScript 代码 动态 地 为 图 片 添加 CSS 样式 ， 核 心 代码 如 下 : 
S$(document) ready(functionO{ 
S$("select").change(functionO{ 
var value = $(this).val|); 
if(value —""){ 
alert(" 您 没有 选择 图 片 样式 "); 
jelsef 
if(value — D){ 
S$("img").css("float"."left"): 
}else{ 
这 value 一 2{f 
S("img").css("float","right"); 
Jelse{ 
S$("img").css({border:"1px red solid"}): 


了 
} 
D); 
D; 
图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 下 拉 列 表 框 和 
内 容 主体 ， 代 码 如 下 : 
<div> 
<table border="1" bordercolor="#00CCEF" ellspacing="0"><tr><td> 
‘<select> 
<option value="> 请 选择 图 片 样式 <joption> 
<option value="1"> 图 片 向 左 浮动 </option> 
<option value="2"> 图 片 向 右 浮动 </option> 
<option value="3"> 为 图 片 添加 边框 </option> 
</select> 
<ltd></tr><tr><td> 
<img sre="pic/img.gif' /> 
&nbsp;&nbsp:&nbsp:&nbsp: 很 久 很 久 以 前 ， 在 中 国 新 疆 地 区 ， 有 一 个 骑 着 毛驴 的 中 年 男人 ， 听 说 他 智慧 过 人 ， 爱 打 抱 不 平 ， 经 常 为 了 
老百姓 的 利益 与 达官 贵人 进行 智慧 的 较量 。 而 且 他 胆量 非凡 ， 总 是 戏弄 那些 达官 显贵 。 在 那里 富 人 都 害怕 他 ， 穷 人 都 喜欢 他 ， 他 的 名 字 叫 做 阿 
凡 


提 
</td></tr></table></div> 


(2) 编写 JavaScript 脚本 ， 代 码 见 关键 技术 。 
图 秘笈 心 法 


心 法 领悟 186: CSS 中 如 何 使 用 float 属性 。 

float 属性 指定 对 象 是 否 浮动 和 如 何 浮动 等 ， 参 数 如 下 : 
回 nne: 对 象 不 浮动 。 

left， 对象 浮 在 左边 。 

right: 对 象 浮 在 右边 。 


高 级 
趣味 指数 : 真人 广 丛 三 


| 
: 


力 实例 说 明 


用 户 在 设计 页 面 时 ， 为 了 达到 整体 协调 的 效果 ， 很 多 时 候 需要 重新 设计 滚动 条 。 本 实例 只 是 更 改 了 滚动 条 
相关 的 色调 ， 没 有 对 其 整体 效果 进行 更 改 ， 运 行 效果 如 图 3.43 所 示 。 
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美食 教程 


下 然 咎 用 】 : 牛肉 一 盘 ， 孜 热 少许 放 入 牛 内 及 调味 刑 ， 小 中 炎 炒 名 再 族 入 孜 兰 即 可 和 全。 
| Ri | 中 


3.43 ”滚动 条 样式 


力 关键 技术 
本 实例 通过 CSS 样式 对 浏览 器 的 滚动 条 等 颜色 进行 更 改 ， 核 心 代码 如 下 : 


td{font-size:9pt} 

BODY { 

SCROLLBAR-BASE-COLOR: #FFADO00:; 
SCROLLBAR-FACE-COLOR: #FFCB29}; 
SCROLLBAR-ARROW-COLOR: #800529; 
SCROLLBAR-TRACK-COLOR: #EEFFCC:; 
SCROLLBAR-DARKSHADOW-COLOR:#FFFFFF:; 
} 


图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 页 面 ， 载 入 CSS 样式 ， 其 关键 代码 如 下 : 


<link href="css/style.css" rel="stylesheet"> 


(2) 编写 CSS 样式 文件 style.css， 代 码 见 关键 技术 。 
图 秘笈 心 法 
心 法 领悟 187: CSS 中 设置 color 属性 的 注意 事项 。 


color 为 要 设置 的 颜色 代码 ， 可 以 是 十 六 进 制 的 ， 如 红 F0000， 也 可 以 是 以 RGB 表示 的 ， 如 RGB (255，0， 
255) 。 在 设置 滚动 条 样式 时 ， 不 必 把 所 有 的 属性 都 用 上 ， 用 户 可 根据 网 页 的 需求 自行 设置 。 


a 
an | | 


i 
力 实例 说 明 


表单 几乎 是 所 有 网 站 都 不 可 或 缺 的 一 个 模块 ， 用 户 可 以 用 它 登录 到 网 站 或 者 填写 个 人 信息 等 。 所 以 对 于 
一 个 Web 开发 者 来 说 ， 学 习 设 置 一 个 优秀 的 表单 样式 是 很 重要 的 。 运行 本 实例 ,通过 CSS 设置 表单 样式 ， 效 
果 如 图 3.44 所 示 。 


3.44 设置 表单 样式 
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力 关键 技术 
本 实例 通过 CSS 样式 对 表单 的 字体 、 标 签 、 文 本 边框 进行 设置 ， 实 现 美化 的 目的 ， 代 码 如 下 : 


margin-top:150px 

} 

#one{ 

margin-left:400px; 
font-family:" 楷 体 GB2312"; 
font-size:16px; 

} 

input{ 

width:150px; 

} 

#e{ 

width:35px: 
background-image:url(../pic/buttom.jpg); 
border:0; 

} 

tee{ 

width:35px: 
background-image:url(../pic/buttom1 jpg): 
border:0; 

; 

#o#n{ 

border:1px #FFCCFF solid; 

} 

table{ 

width:250px: 

height:150px; 
background-image:url(../pic/bg:jpg); 


} 
另外 还 应 用 JavaScript 特效 ， 使 鼠标 覆盖 或 移出 时 文本 框 变 色 ， 代 码 如 下 : 
S$(document) ready(functionO{ 
$("input:lt(2)").mouseover(functionO{ 

S(this).css("background","#BFAFC9"); 

S(this).mouseout(functionO{ 

S(this).css("background", "white"); 
D: 


D: 
D; 


图 设计 过 程 
(1) 创建 index.php 文件 ， 载 入 CSS 样式 、JavaScript 脚本 文件 和 jQuery 类 库 文件 ， 通 过 <div> 定 位 技术 对 
表格 信息 进行 定位 。 创 建 form 表单 ， 设 置 用 户 名 和 密码 文本 框 ， 代 码 如 下 : 


<link type="text/ess" rel="stylesheet" href="css/in.css"/> 

<script type="text/javascript" sre="../js/jquery-1.3.2.js"></script> 
<script type="text/javascript" sre="js/in.js"></script> 

<div> 

<div id="one"> 

<table border="1" bordercolor="#00CCFF" cellspacing="0"><tr><td> 
用 户 名 : <input type="text" id="o" /><br> 

密 &nbsp:&nbsp: 码 :<input type="password" id="n" /><br> 

<input type="button" id="e" valuc=""/><input type="button" id="ee" valuc=""/> 
</ltd></tr></table> 

</div> 

<div> 


(2) 编写 CSS 样式 和 JavaScript 脚本 ， 代 码 见 关键 技术 。 
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心 法 领悟 188: CSS 中 设置 border 属性 的 注意 事项 。 

border 属性 是 复合 属性 ， 如 使 用 该 复合 属性 定义 单个 参数 ， 则 其 他 参数 的 默认 值 将 无 条 件 覆 盖 各 自 对 应 的 
单个 属性 设置 ， 默 认 值 为 medium none。border-color 的 默认 值 将 采用 文本 颜色 。 要 使 用 该 属性 ， 必 须 先 设 定 对 
象 的 height 或 width 属性 ， 或 者 设 定 position 属性 为 absolute。 


实例 189 


力 实例 说 明 


超 链 接 在 Web 开发 中 也 是 很 常见 的 ， 其 主要 作用 是 执行 客户 端的 脚本 跳 转 。 默 认 情 况 下 ， 单 击 之 前 颜色 为 
蓝 色 ， 存 在 下 划 线 样式 ， 单 击 之 后 颜色 为 紫色 ， 同 样 存在 下 划 线 样式 。 但 是 这 种 样式 不 可 能 适合 所 有 的 网 站 色 
调 。 本 实例 介绍 如 何 更 改 超 链 接 的 样式 ， 运 行 效果 如 图 3.45 所 示 。 


图 3.45 设置 超 链接 的 样式 


力 关键 技术 
本 实例 通过 CSS 样式 ， 定 义 <a> 标 签 的 3 个 属性 ， 控 制 超 链接 的 样式 ， 其 核心 代码 如 下 : 
af 


border:1px #FF0000 solid; 
} 

alink{ 

color:#333333; 
text-decoration:none: 


} 

arvisited{ 

color:#666666; 
text-decoration:none; 

} 

a:hover{ 
background-color:#FF0000; 
color#FFFFFF; 

} 


力 设计 过 程 


(1) 创建 index.php 文件 ， 载 入 CSS 样式 文件 ， 编 写 5 个 超 链 接 ， 代 码 如 下 
<div> 
<div id="one"> 
<table border="1" bordercolor="#00CCFF" cellspacing="0" background="pic/bg.ipg"><tr><td> 
<a hre 仁 "#"> 链 接 1</a>&nbsp;<a hre 仁 "# > 链接 2</a>&nbsp:<a hre 仁 "#" > 链接 3</a>&nbsp;<a hre 仁 "#"> 链 接 4</a>&nbsp:<a hre 仁 "#"> 链 接 
4</a>&nbsp:<a href="#"> 链 接 5</a> 
<htd></tr></table> 
</div> 
</div> 


(2) 编写 CSS 样式 ， 代 码 见 关 键 技术 。 
秘笈 心 法 
心 法 领悟 189: 定义 <a> 标 签 的 3 个 属性 。 
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:link: 设置 a 对 象 在 未 被 访问 前 的 样式 表 属 性 。 
:visited: 设置 a 对象 在 其 链接 地 址 已 被 访问 时 的 样式 表 属 性 。 
:hover: 设置 对 象 在 鼠标 悬 停 时 的 样式 表 属 性 。 


eeooosooeeoooooeeoseeoopooooeeooeeooeeooeooeooeoooesooeooneoeeooeeleon enontens 
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力 实例 说 明 


HTML 将 整个 网 页 分 成 头 部 (head) 和 身体 (body) 两 个 部 分 ， 头 部 一 般 包 含 标题 和 引入 的 JavaScript 和 
CSS 样式 等 ; 身体 部 分 主要 是 执行 的 代码 ， 其 中 可 以 包含 表格 、 表 单 和 <div> 标 签 等 元 素 。 对 于 <body> 中 的 元 素 
可 以 进行 CSS 的 样式 美化 ， 但 是 如 果 用 户 想 定义 类 似 全 文 的 一 个 文字 的 样式 ， 则 需要 对 每 个 标签 里 输出 到 页 面 
的 文字 进行 CSS 样式 的 定义 ， 这样 未 免 太 麻烦 ， 因 此 可 以 在 <body> 标 签 中 应 用 CSS 样式 ， 这 样 就 可 以 对 整个 页 
面 中 的 文字 进行 设置 ， 运 行 结果 如 图 3.46 所 示 。 


提供 源码 彻底 查询 ， 快 速 查找 相关 技术 的 顶 
目 应 用 ， 通 过 源 程序 按钮 ， 可 快速 打开 源 程 


D> Fi 


图 3.46 设置 body 的 样式 


图 关键 技术 


本 实例 通过 定义 <body> 标 签 的 CSS 样式 ， 对 整个 页 面 中 的 文字 及 文字 的 颜色 进行 定义 ， 其 核心 代码 如 下 : 


body{ 
font-family:" 楷 体 _GB2312"; 
font-size:14px: 
color:#666666: 

} 


图 设计 过 程 
(1) 创建 index.php 文件 ， 利 用 <table> 标 签 建立 网 页 框架 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表单 ， 
代码 如 下 : 
Es 
‘<script type="text/javascript" sre="../js/jquery-1.3.2.js"></script> 
‘<script type="text/javascript" sre="js/in.js"></script> 
‘<table width="595px" height="448px" align="center" border="1" bordercolor="#0099FF" cellspacing="0" background="pic/bg.ipg"> 


<td> 用 户 名 : <input type="text" id="o" /></td> 
<ltr> 
<tr> 
<td> 密 &nbsp:&nbsp: 码 : <input type="password"” id="0"/></td> 
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<ftr> 
</table> 
<itd> 

<ltr> 
</table> 


(2) 编写 CSS 样式 和 JavaScript 脚本 文件 ， 核 心 代码 见 关键 技术 。 
图 秘笈 心 法 


心 法 领悟 190: 定义 <body> 标 签 属性 的 注意 事项 。 
当 用 CSS 样式 定义 了 <body> 标 签 后 ， 如 果 想 定义 <body> 内 的 元 素 属 性 ， 需 要 对 每 个 元 素 进行 更 改 。 


二 
| | 
ee eee. | 
图 实例 说 明 
在 一 些 大 型 网 站 的 首页 中 ， 为 了 体现 动画 效果 ， 通 常 在 进入 首页 前 添加 一 个 模拟 的 进度 条 ， 通 过 该 进度 条 


实现 打开 网 站 首页 的 前 奏 。 运 行 本 实例 ， 将 自动 加 载 一 个 模拟 的 进度 条 ， 运 行 结果 如 图 3.47 所 示 。 当 进度 条 完 
成 100% 后 ， 自 动 跳 转 到 http://www.mingrisoft.com 网 站 。 


图 3.47 模拟 的 进度 条 


力 关键 技术 


本 实例 主要 应 用 for 循环 语句 控制 进度 条 的 进度 ， 当 进度 条 完成 整个 进度 的 显示 时 ， 自 动 调用 finish0 函 数 ， 
从 而 跳 转 到 指定 的 网 站 。 
另外 ， 本 实例 中 进度 条 的 样式 是 通过 CSS 样式 设置 的 ， 并 应 用 div 层 输出 到 浏览 器 。 


图 设计 过 程 
(1) 应 用 CSS 样式 设置 div 层 及 文字 的 样式 ， 代 码 如 下 


<style type="text/css"> 
div {font-size: 9pt} 

#load {font-size: Opt: cursor: default position: absolute: display:block:width:402:height:20:top:expression((document.body.clientHeight-50)/2); 
left:expression((screen.width-400)/2); display: block: z-index:100:background:#EDECE9} 

.px1 {border: 1px solid :background-color: #FFFFFF:} 


body { 
background-color: #000000: 


} 
.stylel {color: #FFFF00} 
</style> 


(2) 在 <body> 中 应 用 div 层 设计 进度 条 ， 应 用 class 为 div 层 引 用 已 定义 的 CSS 样式 ， 并 添加 部 分 说 明文 


字 ， 然 后 应 用 for 循环 语句 限制 进度 条 完成 整个 进度 的 行程 ， 代 码 如 下 : 
<body onload=finishO> 
<div id-load style="background-color:#000000"><span class="style1"> 请 稍 候 .</span> 
<div class=pxl><img id=line style="background:red" width=14 height=14></div> 
<div class="style1" id=load_txt>loading</div> 
<div> 
<?php 
for(Si=0:Si<500:Sit+H)f 
> 
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<script>load_num("Loading"):</script> 
<Iphp 
<lbody> 
(3) 应 用 JavaScript 脚本 实现 进度 条 的 动态 效果 , 当 进度 条 完成 整个 进度 的 显示 时 ,自动 调用 finish0 函 数 ， 
从 而 跳 转 到 指定 的 网 站 ， 代 码 如 下 : 
<script language=JavaScript> 
var load line i=1; 


var load line_step=500; 

function load_num(txt) 

{load_line i+=400/load line_step; 

load_txtinnerText=txt+" "+Math.floor(load line i/4.00)+"%6"; 


window, i /fwww.mingrisoft.com"; 
} 


<lscript> 


图 秘笈 心 ; 


心 法 领悟 191: JavaScript 脚本 客户 端 跳 转 的 两 种 形式 。 
当 页 跳 转 : 

window.location href="http:// " 

新 页 跳 转 : 


Window.open="http:/" 


高 级 
起 叶 指 才 :页 克 页 
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力 实例 说 明 


在 进行 网 页 排版 时 ， 用 户 可 以 使 用 <table> 标 签 进行 布局 ， 但 是 在 比较 大 的 网 页 中 ， 用 <table> 标 签 布局 会 使 页 
面 代码 变 得 混乱 , 不 容易 解读 , 所 以 笔者 建议 尽量 使 用 <div> 标 签 进 行 页 面 布局 。 运行 本 实例 , 效果 如 图 3.48 所 示 。 


提供 源码 彻底 查询 ， 快 速 查 找 相 关 技 术 的 项 
目 应 用 ， 通 过 源 程 序 按钮 ， 可 快速 打开 源 程 
有 序 ， 方 丁 详 歼 。 


图 3.48 ”<div> 标 签 设计 用 户 注册 页 面 


图 关键 技术 
本 实例 的 关键 点 是 对 <div> 标 签 定位 的 灵活 运用 ， 及 运用 CSS 样式 控制 页 面 的 样式 ， 核 心 代码 如 下 : 
deg 
text-align:center; 
} 
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one{ 
margin-top:100px; 
width:595px; 

height:448px: 
background:url(../pic/bg:jpe); 
} 

input{ 

width:150px; 

height:18px; 

border-left:0; 

border-top:0; 

border-right:0; 
border-bottom: lpx #CCCCCC solid: 
background:#6BACCC; 

} 

two{ 

margin-top:200px; 
margin-left:200px; 
font-family:" 楷 体 _GB2312"; 
font-size:16px 
color#0000FF: 

} 

#pic{ 

border:0; 
background:url(../pic/btjpe): 
width:39px; 

} 


‘three{ 
margin-right:170px; 
} 


力 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 对 网 页 进行 排版 ， 引 入 CSS 样式 和 JavaScript 脚本 ， 编 写 表单 ， 代 码 
如 下 : 


<div class="one"> 
<div class="two"> 
<div> 
上 昵称: <input type="text" /> 


密码 ，<input type="password" /> 
QQ: <input type="text" /> 


住址 ，<input type="text" /> 
</div> 
<div class="three"> 
<input id="pic" type="submit" value="" /> 
</div> 
</div> 
<div> 


(2) 编写 CSS 样式 ， 设 置 文本 标签 和 标签 位 置 定位 ， 代 码 见 关键 技术 。 
国 秘笈 心 法 
心 法 领悟 192: 如 何 定义 文本 框 只 显示 为 一 条 下 划 线 的 CSS 样式 风格 。 


使 文本 框 只 显示 为 一 条 下 划 线 的 操作 很 简单 ， 其 原理 是 将 文本 框 的 左 、 右 、 上 边框 的 border 属性 都 设置 为 
0， 然 后 定义 下 边框 的 CSS 样式 。 以 本 实例 为 例 ， 代 码 如 下 : 


border-left:0: 
border-top:0: 

border-right:0: 

border-bottom: 1px #CCCCCC salid: 
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实例 193 


力 实例 说 明 


论坛 的 浏览 页 面相 信 对 于 所 有 用 户 来 说 并 不 陌生 , 其 主要 功能 是 将 用 户 发 表 的 内 容 供 所 有 人 或 部 分 人 浏览 。 
本 实例 讲解 的 主要 内 容 并 不 是 如 何 实现 浏览 这 一 功能 , 而 是 对 浏览 页 面 的 <div> 布 局 。 运 行 本 实例 , 效果 如 图 3.49 
所 示 。 


帖子 中 心 


四 PiD_ IE 有 i | 
Pb phP 典 亚 针 块 修订 版 ， 已 经 出 版 了 。 乔 
过 上 刻 广 大 读者 批评 指正 。 


图 3.49 论坛 帖子 的 浏览 页 面 


图 关键 技术 
本 实例 的 关键 点 是 利用 <div> 的 定位 技术 对 页 面 进行 合理 布局 ， 其 中 实现 定位 的 div 元 素 控制 的 代码 如 下 : 


.one{ 


background:url(../pic/bgjpg): 
} 

‘three{ 

margin-top:200px; 
margin-lefit:100px; 

} 

‘five{ 

margin-left:100px: 

和 


力 设计 过 程 
(1) 创建 脚本 文件 ， 引 入 CSS 样式 ， 连 接 数据 库 ， 完 成 数据 库 中 数据 的 分 页 输出 ， 代 码 如 下 : 


<div class="one"> 
<div class="two"> 


<?php 
$conn = mysql_connect("localhost", "root","111") or die ("Connect MySQI False"): // 连 接 数据 库 
mysql_select_db("db_database03",$conn) or die ("Connect db False"): 
mysql_query("SET NAMES UTF8"): 
Snum= 1 
Srs = mysql_query("select * from tb_demo01"); 
Smu = mysql_num rows($rs): 
ifisset(S_GET[page])){f 
Spage =$_GET[page]: 


第 3 章 Web 页 面 交互 


jelsef 
Spage = 1; 


} 
if($page < Smu){ /分 页 
> 


es 
<a href="index.php?page=<?php echo ($page+1):?>"> 下 一 页 </a> 
</div> 
<?php 
jelsef 
> 
<div class="three"> 
<a href="index.php?page=<?php echo ($page-1):?>"> 上 一 页 </a> 
<div> 
<?php 
} 
Spag = $page - 1; 
$sqlstr = "select * from tb demo01 limit $pag,1"; 
Srss = mysql query($sqlstr); 
Srey = mysql_fetch_array($rss); 
?> 
<div class="five"> 
<table width="500px" border="1" bordercolor="#FF0000" cellspacing="0"> // 数 据 输出 
<tr> 
<td width="70px"> 用 户 ID</td><td width: 
<t> 
<tr> 
<td><?php echo S$rey[id]?></td><td><?php echo Sreyltitle]?></td><td><?php echo Srey[content]?></td> 
<lt> 
<ltable> 
</div> 
<ldiv> 
(2) 编写 CSS 样式 ， 代 码 如 下 : 
body{ 
margin:0px; 


"150px"> 标 题 </td><td> 内 容 </td> 


.one{ 
margin:auto; 

width:700px; 

height'S00px: 
background:url(./pic/bgjpg); 


td{ 
font-family:" 楷 体 _GB2312"; 
font-size:15px: 
color:#0099FF; 

} 

fivef 

margin-left:100px; 

} 


a 
{ 

font-family:" 楷 体 _GB2312"; 
border-bottom:0: 
border-left:2px #FF0000 solid; 
border-right:2px #FF0000 solid: 
border-top:2px #FF0000 solid: 

} 

alink{ 

text-decoration:none; 
color:#000000; 

} 
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arvisited{ 
text-decoration:none; 


心 法 领悟 193: 相对 路 径 与 绝对 路 径 。 

相对 路 径 与 绝对 路 径 是 在 日 常 程序 开发 过 程 中 经 常用 到 的 两 个 概念 。 相 对 路 径 是 指 以 当前 文件 为 参照 物 ， 
其 他 文件 的 位 置 ， 绝 对 路 径 指 文件 的 绝对 位 置 ， 即 文件 在 本 机 中 的 绝对 位 置 。 以 本 实例 为 例 ， 以 background: 
ul(../pic/bg.jpg); 引 入 背景 图 片 ， 此 路 径 为 相对 路 径 。 


CR 

后 台 管理 页 面 高 级 | 
4 起 味 指数 : 贾 页 页 页 | 
国 实例 说 明 


所 有 的 Web 开发 者 几乎 都 是 从 最 简单 的 HTML 语言 开始 学 起 ， 所 以 较 <div> 标 签 来 说 ， 程 序 员 更 喜欢 用 
<table> 标 签 来 完成 网 页 框架 的 布局 。 但 是 从 网 站 优化 的 角度 来 说 ，<div> 标 签 确实 优 于 <table> 标 签 。 本 实例 通过 
设计 后 台 管 理 页 面 ， 着 重 阐 述 如 何 使 用 <div> 布 局 。 运 行 本 实例 ， 效 果 如 图 3.50 所 示 。 


FIWRINTY 


落后 台 管 理 系统 We wi Wi Tf : 天 是 : 20loss 有 oz 日 有 
加 你 当前 的 位 置 : [业务 中 心 ]-[ 交 的 6 件 ] [TY 
厂 序号 接收 号 码 时 间 邮件 地 址 内 容 基本 换 作 
看 企业 中 心 ol sense 二 二 0 信 编 辑 。 着 出 除 
日 基地 业务 Foz enue esos we a 信 的 和 。 其 册 除 
外 配置 环境 口 信访 可 。 其 删除 
下 密 保 修改 口 个 编程 。 办 天 除 
口 2 坊 旨 其 册 除 
| 口 过 坑 各 等 出 除 
日 系统 维护 口 Fin Wh 
入 口 安全 中 心 后 沁 编 辑 。 其 删 除 
日 措施 手段 rc 少 沪 本 其 册 除 
日 设置 窑 保 0 他 的 本 。 共 册 除 
而 重新 申请 共有 120 条 记录 ,当前 第 1/10 页 首页 3 让 二 页] 不 二 页 ]|[ 怖 页 转 到 第 | | 页 [地 转 | 


3.50 ”后 台 管理 页 面 


力 关键 技术 


本 实例 利用 <div> 标 签 进 行 网 页 布局 ， 并 利用 CSS 定义 宽 、 高 等 属性 。 实 现 定位 的 核心 代码 如 下 : 
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height:600px: 


} 
b{ 


margin:0px; 

width:1023px; 

height:80px: 
background:url(../pic/top.jpg); 
} 

<{ 

margin:0px; 

width:16Spx; 

height:310px: 
position:absolute; 
background:url(../pic/leftjpg); 


background:url(../pic/right.JPG); 
float:right: 
} 


<{ 
background:url(../pic/down.JPG); 
width:1023px: 

height:10px; 

} 


图 设计 过 程 


(1) 创建 index.php 文件 ， 利 用 <div> 标 签 对 网 页 进行 布局 ， 代 码 如 下 : 
<div class="a"> 
<div class="b"></div> 
<div class="e"> </div> 
<div class="d"> 
</div> 
<div class="e"></div> 
</div> 


(2) 编写 CSS 样式， 代码 见 关键 技术 。 
国 秘笈 心 法 
心 法 领悟 194: CSS 样式 中 ， 如 何 使 文本 或 标签 居中 显示 。 


在 <div> 标 签 定位 中 ， 如 果 想 使 <div> 标 签 内 部 的 内 容 或 标签 居中 显示 ， 可 以 使 用 CSS 中 的 text-align 属性 
实现 。 
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力 实例 说 明 


在 设计 网 页 的 过 程 中 ,能 否 控制 好 各 个 模块 的 位 置 是 很 重要 的 ， 而 控制 这 些 模块 的 标签 中 <div> 是 最 常用 的 
标记 。 利 用 <div> 标 签 再 加 上 CSS 对 其 进行 样式 控制 ， 可 以 实现 很 多 效果 。 下 面 讲解 <div> 标 签 的 使 用 特点 和 应 
用 技巧 。 运 行 本 实例 ， 效 果 如 图 3.51 所 示 。 
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图 3.51 利用 <div> 标 签 布局 


图 关键 技术 


本 实例 用 到 的 属性 包括 margin、width、height、float、clear， 具 体 说 明 如 下 : 

(1) margin: 控制 模块 与 外 边 距 的 距离 。 其 中 ， 如 果 只 定义 1 个 参数 ， 表 示 到 四 边 的 边 距 ， 定 义 3 个 参数 
表示 到 上 、 左 / 右 、 下 的 边 距 ， 定 义 2 个 参数 表示 到 上 /下 和 左 / 右 的 边 距 。 

(2) width: 定义 <div> 模 块 的 宽度 。 

(3) hight， 定义 <div> 模 块 的 高 度 。 

(4) float: 指定 <div> 对 象 模块 如 何 浮 动 ， 其 中 包括 3 个 参数 ， 分 别 是 left、right、none， 表 示 向 左 浮动 、 
向 右 浮 动 、 不 浮动 。 

(5) clear: 指定 是 否 允许 浮动 对 象 ， 其 中 包括 4 个 参数 ， 即 left、right、both、none， 分 别 表示 清除 左 侧 浮 
动 、 清 除 右 侧 浮动 、 清 除 两 侧 浮动 、 不 清除 浮动 。 


图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 定 位 技术 设计 网 页 结构 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 
<div class="f"></div> 
<div class="j"></div> 
</div> 
<div class="c"></div> 
<div class="d"> 
<div class="g"></div> 
<div class="h"></div> 
<div class="i"></div> 
<div> 
<div class="e"> 
<div class="k"></div> 
<div> 
<div> 
(2) 编写 CSS 样式 ， 将 <div> 模 块 定位 到 指定 位 置 并 添加 背景 颜色 ， 代 码 如 下 : 
body{ 


margin:0px: 
background:#CCCCCC: 
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} 

af 
margin:auto; 
width:700px; 
height:600px: 
background:#FFFFFF:; 
} 

bf 
margin:Spx; 
width:700px; 
height:SOpx:; 


background:#CCCCCC: 


} 

£{ 

margin:2px; 
width:200px; 
height:75px; 
float:left; 
background:#FF0000; 


height:75px:; 
float:right: 

clear:left; 
background:#0099FF; 
} 

ef 

margin:Spx; 
width:714px; 
height:30px; 
background:#666666; 


height:400px: 
background:#6699FF; 


height:400px: 
background:#00FF00; 
float:left: 

} 

ht{ 

margin:Spx; 
width:300px; 
height:400px; 
background:#990000; 
float:left: 

} 

这 

margin:Spx: 
width:275px; 
height:400px; 
background:#99FF33; 
float:right: 

} 

ef 

margin:Spx: 
width:714px; 
height100px: 
background:#CC66CC: 
} 

kf{ 

margin:Spx auto Spx: 
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width:200px; 
height:90px; 
background:#FFFFO00; 
} 


国 秘笈 心 法 
心 法 领悟 195: clear 属性 的 具体 应 用 。 


假设 外 部 <div> 标 签 定义 宽度 为 400 个 像素 ， 内 部 定义 的 两 个 <div> 标 签 的 总 宽度 为 450 个 像素 ， 如 果 内 部 
右 侧 的 <div> 标 签 不 能 清除 左 侧 的 浮动 的 话 ， 将 会 产生 换行 效果 。 


图 实例 说 明 


在 比较 小 的 博客 中 ， 网 页 一 般 分 为 上 、 中 、 下 3 个 部 分 ， 中 间 部 分 又 分 左 、 右 两 个 部 分 。 如 果 利 用 HTML 
的 <table> 标 签 实现 ， 则 需要 多 个 <table> 标 签 进行 嵌 套 ， 但 是 如 果 利用 <div> 标 签 ， 结 构 就 比较 明朗 了 。 下 面 来 实 
现 这 一 实例 ， 运 行 结 果 如 图 3.52 所 示 。 


pg 
高 级 | 
起 听 指 数 宙 页 寅 od 


图 3.52 页 面 布局 之 2 列 左 罕 右 宽 高 度 自 适应 


图 关键 技术 


本 实例 的 关键 点 是 如 何 实现 <div> 模 块 的 高 度 自 适应 。 其 实 实现 这 一 功能 很 简单 ， 只 需要 定义 height 属性 为 
auto 即 可 ， 代 码 如 下 : 


height:auto: 


图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 对 网 页 进行 布局 并 输出 提示 文字 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 


<div class="f'></div> 
<div class="j"></div> 


<div> 
<div class="c"></div> 
<div class="d"> 

<div class="g"> 
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明日 科技 <br>PHP 开发 实录 <br> 典 型 模块 大 全 <br> 


<div> 
<div class="h"> 


明 <br> 日 <br> 科 <br> 技 <br> 编 <br> 程 <br> 词 <br> 典 <br> 修 <br> 订 <br> 版 <br> 马 <br> 上 <br> 就 <br> 要 <br> 上 <br> 市 <br> 啦 1! 


</div> 
</div> 
<div class="e"> 


<div class="k"></div> 


<div> 
<div> 


(2) 编写 CSS 样式 ， 定 义 <div> 模 块 的 宽度 和 高 度 ， 并 为 输出 的 文字 定义 样式 ， 代 码 如 下 : 


body{ 
margin:0px: 
background:#CCCCCC: 


width:700px; 
height:SOpx; 
background:#CCCCCC; 


width:200px; 
height:75px: 
float:left; 
background:#FF0000; 


width:500px; 
height:75px: 
float:right: 
clear:left; 


height:400px: 
background:#6699FF: 
} 

‘2{ 

margin:Spx; 
width:200px; 
heightauto: 
background:#00FFO0; 
float:left: 

font-family:" 楷 体 _GB2312":; 
font-size:16px: 

} 
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hf{ 
margin:5px: 
width:485px: 
height:auto; 
background:#990000; 
float:right: 

clear:left: 


font-family:" 楷 体 _GB2312"; 


color:#FFFFFF: 
font-size:18px; 


height100px: 
background:#CC66CC; 
} 

k{ 

margin:Spx auto Spx; 
width:200px; 
height:90px: 
background:#FFFF00; 
} 


国 秘笈 心 法 
心 法 领悟 196: 什么 是 高 度 自 适 应 。 


所 谓 的 高 度 自 适应 是 指 根据 文本 内 容 的 多 少 自动 调整 相应 的 高 度 ， 这 样 设置 的 优点 是 可 以 完全 不 浪费 网 页 
空间 ， 而 且 使 页 面 效果 饱满 丰富 。 高 度 自 适应 在 网 页 设计 中 被 广泛 使 用 。 
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: 
趣味 指数 : 克 友 友 友 | 


实例 196 已 经 讲解 了 页 面 布局 中 左 窗 右 宽 的 情况 ， 本 实例 介绍 2 列 固定 宽度 的 实现 方法 。 运 行 本 实例 ， 效 
果 如 图 3.53 所 示 。 


RE OR TE 
司 


图 3.53 页 面 布局 之 2 列 固 定 宽度 + 头 部 + 导航 + 尾部 
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图 关键 技术 
本 实例 设 定 


‘2{ 

margin:Spx; 
width:340px; 
height:300px:; 
background:#00FF00; 
float:left: 

} 

h{ 

margin:Spx; 
width:340px; 
height:300px: 
background:#990000; 
float:right: 

clear:left; 

} 


图 设计 过 程 


区 


定 宽度 的 方法 是 定义 width 属性 为 固定 值 ， 代 码 如 下 : 


(1) 创建 脚本 文件 ， 利 用 <div> 标 签 对 网 页 进行 布局 并 输出 提示 文字 ， 代 码 如 下 ; 


<div class="a"> 
<div class="b"> 
<div class="f> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="e"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"><h1> 长 春 市 明日 科技 有 限 公司 </h1></div> 
<div class="h"> 明 日 科技 图 书 ， 新 书 上 市 啦 </div> 
</div> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
</div> 


(2) 编写 CSS 样式 ， 定 义 <div> 相 关 属性 并 定义 页 面 输出 字体 的 样式 ， 代 码 如 下 : 


height:500px: 
background:#FFFFFF; 
font-family:" 经 典 趣 体 简 "; 
font-size:18px; 
color:-#FFFFFF; 


width:200px: 
height:75px: 
float:left: 
background:#FF0000: 
} 

EL 

margin:2px: 
width:500px; 
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height75px: 


国 秘笈 心 法 
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心 法 领悟 197: float 属性 的 使 用 方法 。 


在 定义 身体 部 分 时 ， 如 果 身 体 部 分 只 有 两 部 分 ， 可 以 利用 float 属性 ， 一 侧 向 左 浮动 ， 一 侧 向 右 浮动 ， 但 是 
如 果 身 体 部 分 分 为 3 个 部 分 ， 那 么 定义 为 以 左面 起 ， 前 两 个 向 左 浮动 ， 最 后 一 个 向 右 浮动 为 好 。 


人 
趣味 指数 : 但 食 食 食 


实例 198 


国 实例 说 明 


实例 196 和 实例 197 都 是 以 中 间 为 两 个 模块 进行 布局 。 本 实例 讲解 中 间 为 3 个 模块 的 实例 ， 并 且 实 现 左 右 


侧 固 定 ， 中 间 自 适应 居中 显示 ， 运 行 效果 如 图 3.54 所 示 。 
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图 3.54 页 面 布局 之 3 列 左右 侧 固 定 中 间 自 适应 居中 


图 关键 技术 


本 实例 的 关键 点 是 如 何 实现 中 间 模 块 自 适应 居中 。 答 案 很 简单 ， 将 模块 的 margin 属性 设置 为 上 下 方向 与 边 
距 为 5 个 像素 ， 左 右 方向 为 auto 自动 设置 即 可 ， 核 心 代码 如 下 : 
h{ 


margin:5px auto; 
width:38Spx; 
height:auto:; 
background:#FFCCFF; 
float:left; 
text-align:center; 


} 
图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 进行 网 页 定位 布局 ， 其 中 包括 头 部 、 颈 部 、 身 体 部 分 和 脚 部 ， 代 码 


如 下 : 
<div class="a"> 
<div class="b"> 
<div class="f'> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="c"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<h1> 长 春 市 明日 科技 有 限 公 司 </h1> 
</div> 
<div class="h"> 
明日 科技 图 书 ， 新 书 上 市 啦 
</div> 
<div class="i"> 
敬 请 期 待 实战 范例 宝典 
</div> 
<ldiv> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
<div> 
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(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 宽 和 高 ， 并 定义 页 面 输出 字体 的 样式 ， 代 码 如 下 : 
body{ 

margin:0px: 
background:#CCCCCC: 

} 

af 

margin:auto; 
width:700px; 
height:500px: 
background:#FFFFFF:; 
font-family:" 经 典 趣 体 简 "; 
font-size:18px: 
color-#FFFFFF; 


width:700px; 
height:80px: 
background:#CCCCCC; 
} 

ff 

margin:2px; 
width:200px; 
height:75px; 
float:left; 
background:#FF0000; 
i{ 

margin:2px; 
width:S00px; 
height:75px: 
float:right; 

clear:left; 
background:#0099FF; 


height:300px: 
background:#6699FF: 


margin:Spx auto: 
width:385px: 
height:auto: 
background:#FFCCFF: 
float:left; 
text-align:center; 

} 

这 

margin:Spx: 
width:150px: 
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height:300px: 


心 法 领悟 198: 使 数据 居中 显示 的 方法 。 
CSS 样式 中 有 一 个 text-align 属性 ， 相 当 于 使 用 <table> 标 签 中 的 center 属性 ， 可 以 使 页 面 数据 居中 显示 。 


gas 
图 实例 说 明 


灵活 地 控制 页 面 中 <div> 标 签 的 宽度 和 高 度 是 使 用 <div> 标 签 的 核心 。 本 实例 实现 身体 部 分 2 列 右 侧 固 定 左 
侧 自 适应 宽度 ， 未 知 高 度 + 头 部 + 导航 + 尾部 的 页 面 布局 ， 如 图 3.55 所 示 。 


ER 
长 春 市 明日 笠 技 有 有限 侠 司 


3.55 页 面 布局 之 2 列 右 侧 固 定 左 侧 自 适应 宽度 


力 关键 技术 
本 实例 的 关键 点 是 实现 身体 部 分 左 侧 自 适应 宽度 且 未 知 高 度 。 实 现 思想 是 设置 width、height 属性 ， 代 码 
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height:auto; 
background:#00FF00; 
float:left; 

} 


图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建立 网 页 的 主体 架构 ， 输 出 文本 信息 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 
<div class="f'> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="e"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<hl> 长 春 市 明日 科技 有 限 公司 <hl> 
</div> 
<div class="h"> 
明日 科技 图 书 ， 新 书 上 市 啦 
</div> 
</div> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
</div> 
(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 具体 属性 ， 并 更 改 输出 文本 的 样式 ， 代 码 如 下 : 
body{ 
margin:0px: 
background:#CCCCCC; 
} 
a{f 
margin:auto; 
width: 700px; 


18px: 
color:#FFFFFF: 


height:80px: 
background:#CCCCCC: 


background:#FF0000: 
} 

i{ 

margin:2px: 
width:500px: 
height:75px: 
float:right: 

clear:left: 
background:#0099FF: 
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background:#00FF00: 


text-align:center; 

} 

ef 

margin:Spx; 
width:714px:; 
height:100px; 
background:#CC66CC: 


图 秘笈 心 法 


心 法 领悟 199: 关键 字 auto 的 使 用 。 
在 <div> 标 签 中 ， 如 果 不 知 道 该 标签 的 具体 宽度 和 长 度 或 者 与 四 边 的 距离 ， 可 以 将 这 些 属性 设置 为 auto。 这 
样 可 以 让 <div> 标 签 的 长 度 和 宽度 自动 调节 。 


固定 右 侧 自 适应 宽度 + 底 平 齐 ) ”高 级 | 


实例 200 趣味 指数 : 让 让 俱全 | 


力 实例 说 明 


利用 <div> 设 计 页 面 时 ， 有 很 多 很 小 的 技巧 ， 灵 活 地 掌握 这 些 技巧 可 以 使 用 户 对 页 面 设计 葡 然 开朗 。 本 实例 
主要 实现 身体 部 分 的 2 列 左 侧 固 定 右 侧 自 适 应 宽度 ， 未 知 高 度 且 底部 平 齐 + 头 部 + 导航 + 尾部 的 页 面 布局 ， 运 行 
效果 如 图 3.56 所 示 。 
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长 琳 市 明日 科技 态 除 
公司 


图 3.56 页 面 布局 之 2 列 左 固定 右 自 适 宽度 + 底 平 齐 


图 关键 技术 


本 实例 的 关键 点 是 实现 身体 部 分 右 侧 自 适应 宽度 且 未 知 高 度 ， 底 部 平 齐 。 实 现 思想 是 设置 width、height、 
margin 属性 ， 代 码 如 下 : 
ht{ 


margin:5px Spx Opx Spx; 
width:auto: 

heightauto: 
background:#FFCCFF: 
float:right: 


text-align:center; 
图 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建立 网 页 的 主体 架构 ， 输 出 文本 信息 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 
<div class="f"> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="c"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<hl> 长 春 市 明日 科技 有 限 公司 <Ihl> 
</div> 
<div class="h"> 
明 <br> 日 <br> 科 <br> 技 <br> 图 <br> 书 <br> 新 <br> 书 <br> 上 <br> 市 <br> 啦 <br> 敬 <br> 请 <br> 关 <br> 注 <br> 
<ldiv> 
</div> 
<div class="e"> 
<div class="k"> 我 是 脚 部 </div> 
</div> 
<div> 


(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 具体 属性 ， 并 更 改 输出 文本 的 样式 ， 代 码 如 下 : 
body{ 


margin:Opx: 
background:#CCCCCC: 
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af 
margin:auto; 

width:700px: 
height:500px: 
background:#FFFFFF: 
font-family:" 经 典 趣 体 简 "; 
font-size:18px: 
color#FFFFFF; 


width:700px; 
height:80px; 
background:#CCCCCC: 
} 

f{ 

margin:2px; 
width:200px; 
height:75px: 

float:left; 
background:#FF0000; 


height:75px:; 
float:right: 
clear:left; 
background:#0099FF; 
} 


width:714px; 
height:30px: 
background:#666666; 


width:714px; 
height:300px; 
background:#6699FF; 
} 


height:300px; 
background:#00FFO00; 
float:left: 

} 

hf 

margin:Spx Spx Opx Spx: 
width:auto: 
height:auto: 
background:#FFCCFF:; 
float:right: 
text-align:center; 


width:714px: 
height:100px: 
background:#CC66CC; 
} 

kf{ 

margin:Spx auto Spx: 
width:200px: 
height:90px: 
background:#FFFFO0; 
color:-#000000; 

} 


2S1 
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图 秘笈 心 法 
心 法 领悟 200， 属 性 margin 与 底部 平 齐 。 


margin 属性 在 实例 185 中 已 经 讲解 过 ， 所 谓 的 底部 平 齐 就 是 指 下 边 距 为 0 像素 ， 所 以 只 要 设置 当前 模块 的 
下 边 距 属性 值 为 0 像素 即 可 。 


定 左 侧 自 适应 宽度 + 底 平 齐 ) 高级 
趣味 指教 : 依依 依依 


实例 201 


力 实例 说 明 
本 实例 是 实例 200 的 对 照 ， 意 在 使 读者 对 <div> 定 位 技术 有 深入 的 了 解 ， 运 行 结果 如 图 3.57 所 示 。 


长 
束 
市 
明 
9 
简 
接 
有 
限 


3.57 页面 布局 之 2 列 右 固定 左 自 适 宽度 + 底 平 齐 


力 关键 技术 
本 实例 的 方法 与 实例 200 相同 ， 这 里 不 再 次 述 。 
力 设计 过 程 
(1) 创建 脚本 文件 ， 利 用 <div> 标 签 建 立 网 页 的 主体 架构 ， 输 出 文本 信息 ， 代 码 如 下 : 


<div class="a"> 
<div class="b"> 
<div class="f> 我 是 头 部 </div> 
<div class="j"> 我 也 是 头 部 </div> 
</div> 
<div class="c"> 我 是 颈 部 </div> 
<div class="d"> 
<div class="g"> 
<hl> 长 春 市 明日 科技 有 限 公 司 <hl> 
<ldiv> 
<div class="h"> 
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明 <br> 日 <br> 科 <br> 技 <br> 图 <br> 书 <br> 新 <br> 书 <be> 上 <be> 市 <br> 啦 <br> 敬 <br> 请 <br> 关 <br> 注 <br> 


(2) 编写 CSS 样式 ， 定 义 <div> 标 签 的 具体 属性 ， 并 更 改 输出 文本 的 样式 ， 代 码 如 下 : 
body{ 

margin:0px; 
background:#CCCCCC; 

} 

af 

margin:auto; 
width:700px; 
height:500px: 
background:#FFFFFF; 
font-family:" 经 典 趣 体 简 "; 
font-size:18px; 
color:#FFFFFF; 


float:left: 
background:#FF0000; 


height:75px; 
float:right:; 

clear:left; 
background:#0099FF; 


height:30px: 
background:#666666; 
} 

df 

margin:Spx; 
width:714px; 
height:300px: 
background:#6699FF; 
} 

‘g{ 

margin:Spx Spx Opx Spx; 
width:auto: 
height:auto; 
background:#00FF00: 
float:left; 


height:300px: 
background:#FFCCFF: 
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图 秘笈 心 ; 


心 法 领悟 201: padding 补丁 边 距 。 
本 实例 中 ， 因 为 设置 底部 平 齐 ， 所 以 右 侧 固定 宽度 的 模块 就 可 能 与 底 边 距 不 是 5 个 像素 的 距离 ， 为 了 整体 
的 美感 效果 ， 可 以 为 右 侧 模块 设置 padding 补丁 边 距 ， 设 置 好 合适 距离 后 ， 显 示 效 果 如 图 3.57 所 示 。 


3.6 弹出 窗口 


弹出 窗口 经 常 在 网 站 中 使 用 ， 如 弹出 式 广告 或 网 站 公告 及 打开 居中 显示 详细 信息 的 新 窗口 等 。 所 以 掌握 设 
计 弹 出 窗口 的 技术 ， 也 许 会 给 设计 的 网 站 带 来 额外 的 效益 。 


实例 202 趣味 指数 : 容 让 让 全 


力 实例 说 明 


JavaScript 这 门 脚本 语言 的 功能 很 强大 ,尤其 是 在 网 页 特效 的 处 理 上 更 是 有 其 独到 之 处 。 本 实例 将 讲述 的 是 
通过 JavaScript 代码 控制 ， 弹 出 指定 尺寸 的 无 边框 窗口 ， 如 图 3.58 所 示 。 


文件 中 护驾) 查看 WW ”| 圳 
地 址 四 ) | 估 http /| 加 甘 到 | 外接 


单 击 此 区 域 
弹出 窗口 


图 3.58 单 击 跳 转 图 
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图 关键 技术 
本 实例 主要 是 利用 JavaScript 代码 ， 控 制 弹 出 窗口 的 尺寸 ， 核 心 代码 如 下 : 


selfresizeTo(250.180): 

width=screen width: 

height=screen height: 
self.moveTo((width-240)/2,(height-139)/2): 


图 设计 过 程 


(1) 创建 脚本 文件 ， 利 用 <div> 标 签 定位 技术 建立 网 页 架构 ， 引 入 CSS 文件 ， 当 单 击 图 标 按钮 时 发 生 跳 转 ， 
代码 如 下 : 
<div class="a"><img sre="pic/bgjpg" border="0" usemap="#Map" /> 
<map name="Map" id="Map"><area shape="rect" coords="469.298.541.382" href="in.php" /></map> 


<ldiv> 
(2) 创建 脚本 文件 ， 命 名 为 iphp， 此 文件 执行 跳 转 后 的 代码 。 另 外 ， 在 此 文件 中 建立 form 表单 ， 代 码 
如 下 : 
<div class="c"> 
用 户 名 : <input type="text" name="text"><br> 
密 &nbsp:&nbsp: 码 : <input type="password"><br> 
<input type="button" class="one" valuc="">&nbsp:&nbsp:<input type="button" class="two"value=""> 
</div> 
(3) 编写 JavaScript 脚本 ， 定 义 网 页 窗口 的 尺寸 并 定义 当 鼠 标 覆 盖 和 移 开 文本 框 时 产生 的 变色 效果 ， 代 码 
如 下 : 
S$(document) ready(function(){ 
self.resizeTo(250,180); // 定 义 窗口 的 宽 和 高 
width=screen.width; 
height=screen.height; 
sclfmoveTo((width-240)/2.(height-139)/2): 
$("input:eq(0)").mouseover(functionO{ // 当 鼠标 覆盖 时 
$("input:eq(0)").css("background","#FFCCFF");: 
S$("input:eq(0)").mouseout(functionO{ // 当 鼠标 移 开 时 
S$("input:eq(0)").css("background","#FFFFFF"): 


jy 
S("inputeq(1D))mouseovertfunction0{ 
S$("input:eq(1)").css("background","#FFCCFF"): 
S$("input:eq(1)").mouseout(functionO{ 
S("input:eq(1)").css("background","#FFFFFF"): 
ba 
D; 
图 秘笈 心 法 
心 法 领悟 202: HTML 的 <map> 标 签 。 
如 果 用 户 使 用 的 编程 工具 是 Dreamweaver， 那 么 对 于 <map> 标 签 应 该 并 不 陌生 ， 此 标签 的 主要 作用 是 当 鼠 
标 单 击 指定 区 域 时 ， 网 页 发 生 跳 转 。 


的 

高 级 | 

实例 203 起 味 指教 : 相机 页 宣 | 
实例 说 明 


通常 用 户 在 使 用 正 浏览 器 浏览 网 页 时 ， 浏 览 器 窗口 包括 标题 栏 、 菜 单 栏 和 状态 栏 等 固定 内 容 。 虽 然 菜单 栏 
和 状态 栏 可 以 通过 设置 而 隐藏 ， 但 是 标题 栏 却 不 能 隐藏 ， 即 使 将 网 页 全 屏 显示 也 不 能 将 其 去 除 。 有 时 为 了 网 站 
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的 整体 效果 考虑 ， 需 要 将 网 页 设置 为 全 屏 显 示 。 例 如 ， 在 明日 网 络 宽带 影院 网 站 中 ， 为 了 给 用 户 以 更 真实 的 感 
觉 ， 就 可 以 将 整个 网 站 的 主页 面 设置 为 全 屏 显示 模式 ， 如 图 3.59 所 示 ， 从 图 中 可 以 看 出 该 页 面 中 还 设计 了 “ 退 
出 ” 超 链接 ， 可 以 方便 浏览 者 随时 离开 影院 ， 这 也 是 设计 全 屏 显 示 时 需要 注意 的 问题 ， 否 则 浏览 者 会 因 找 不 到 
出 口 而 烦恼 。 


明日 网 络 宽带 影院 


图 3.59 全 屏 显 示 


图 关键 技术 


本 实例 主要 通过 window 对 象 的 open0 方 法 ， 并 借助 一 个 中 转 页 实现 ， 当 中 转 页 运行 时 调用 open0 方 法 打 
开 一 个 全 屏 显 示 的 窗口 (使 用 window 对 象 的 open0 方 法 中 的 参数 fullscreen=1 实现 ) ， 并 关闭 打开 中 转 页 的 
窗口 。 


图 设计 过 程 
新 建 一 个 空 的 PHP 页 面 (页 面 中 可 以 没有 任何 页 面 布局 元 素 或 内 容 ) ， 命 名 为 index.php。 该 页 面 只 是 起 到 


一 个 页 面 跳 转 的 作用 ， 主 要 应 用 JavaScript 脚本 自 定义 一 个 MM_c0 函 数 ， 并 应 用 window 对 象 的 open() 方 法 打 
开 一 个 新 的 formal.htm 页 ， 设 置 参数 fullscreen=1， 从 而 实现 打开 窗口 的 全 屏 显 示 ， 代 码 如 下 : 


<object type="application/x-oleobject" id=closes classid="clsid:adb880a6-d8ff-11cf-9377-00aa003b7a11"> 


closes Click0: 
window.open("formal htm","", "fullsereen=1"): 


<lscript> 
国 秘笈 心 法 
心 法 领悟 203: 全 屏 显 示 的 主要 应 用 。 


用 户 在 浏览 类 似 于 土豆 、 优 酷 等 网 站 的 视频 时 ， 经 常会 看 到 播放 器 的 下 方 存在 一 个 全 屏 显 示 的 按钮 ， 其 实 
现 方法 与 本 实例 大 同 小 异 ， 只 是 使 用 的 控制 方法 不 同 而 已 。 
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高 级 | 
实例 204 趣味 指数 ; 容 丰 丰 宙 | 


力 实例 说 明 


在 网 站 开发 过 程 中 ， 用 户 经 常 要 求 在 客户 端 应 用 自 定义 颜色 来 改变 某 些 信息 或 控件 等 的 颜色 值 ， 如 留言 本 
中 的 文字 颜色 、 控 件 背 景色 等 ， 通 过 在 网 页 中 加 入 一 个 网 页 拾 色 器 即 可 实现 。 运 行 本 实例 ， 将 在 页 面 中 显示 如 
图 3.60 所 示 的 网 页 拾 色 器 ， 当 用 户 单 击 颜色 块 时 ， 就 会 弹出 一 个 提示 框 ， 提 示 其 所 选 的 颜色 值 是 多 少 ， 通 过 选 
择 的 颜色 值 来 改变 网 页 的 背景 色 。 


图 3.60 网 页 拾 色 器 


力 关键 技术 


本 实例 的 关键 点 是 在 实现 网 页 拾 色 器 时 ， 应 用 JavaScript 的 数组 。 创 建 数组 有 以 下 3 种 方法 : 
(1) 无 参数 调用 ， 语 法 格式 如 下 : 
varh=new Amay0: 
(2) 指定 数组 前 n 个 元 素 的 值 ， 语 法 格式 如 下 : 
var h = new Array(arglist): 
其 中 参数 arglist 是 一 个 用 逗号 隔 开 的 值 表 ， 这 些 值 用 于 给 variant 所 包含 的 数组 的 各 元 素 赋值 。 如 果 不 提供 
参数 ， 则 创建 一 个 长 度 为 0 的 数组 。 
(3) 指定 数组 的 元 素 个 数 ， 语 法 格式 如 下 : 
var h =new Amay(n); 
其 中 参数 n 是 指定 数组 的 长 度 。 由 于 在 JavaScript 中 ， 数 组 的 第 1 个 元 素 的 下 标 值 为 0， 所 以 n 的 值 为 数组 
的 最 大 下 标 值 加 1。 


图 设计 过 程 
(1) 创建 需要 调用 网 页 拾 色 器 的 页 面 ， 在 该 页 面 中 添加 一 个 文本 框 ， 将 文本 框 设 置 为 只 读 ， 同 时 将 文本 框 
的 背景 色 设置 为 黑色 ， 并 在 该 文本 框 的 onClick 事件 中 调用 自 定义 的 JavaScript 函数 colorpick0， 代 码 如 下 : 


<input name="eolor' type="text" id="color" size="3" readonly="yes" style="background-color#CCFF00" onClick="colorpick(this):"> 


(2) 编写 自 定义 的 JavaScript 函数 colorpick0， 用 于 打开 网 页 对 话 框 调 用 网 页 拾 色 器 ， 并 用 网 页 拾 色 器 的 


q 
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返回 值 设 置 文本 框 的 背景 色 和 网 页 的 背景 色 ， 代 码 如 下 : 
<script language="javascript"> 
function colorpick(field){ 
var rtn = window.showModalDialog("color.php"."™"."dialog Width:225px:dialogHeight:170px:status:no:help:no:scrolling=no:scrollbars=no"); 
if(rtn!=null) 
document.body.style.background=rtn: 
ficld.style.background=rtn: 
retum; 
} 


<lscript> 


(3) 制作 网 页 拾 色 器 页 面 color.php， 关 键 代码 如 下 : 


<script language="JavaScript"> 


function action(RGB) { 
parent.window.retumValue="#"+RGB:; 
window.closeO: 


} 

function Meell(R. G. B) { 
document.write('<td bgcolor="# +R+ G+B+">); 
document write(<a href="#" onClick="action(\" + (R + G+ B) + \)">); 
document write( <img border=0 height=12 width=12 \)" alt-\#+R+G+B+\>"); 
document.write('</a>"); 
document.write('</td>"); 


} 
function Mtr(R, B) { 
document.write('<tr>"): 
for (vari=0;i<6;++i) { 
Mcell(R. hfi], B): 
} 


document. write('</tr>") 


} 
function Mtable(B) { 
document. wri 


document. write('</table>"); 


} 
function Mcube() { 
document.write('<table cellpadding=0 cellspacing=0 border=0><tr>"); // 
for (vari=0:1<6: ++i) { 
if(i%3=—0){ 
document.write('<tr>"); 


} 
document.write('<td bgcolor="#FFFFFF">"): 
Mtable(h[i]) 
document.write('</td>"); 
} 
if(i%3==0){ 
document.write('</tr>"); 
} 
document.write('</tr></table>"): 
} 
Meube0 
</script> 


力 秘笈 心 法 


心 法 领悟 204: 浅 谈 variant 变量 。 
本 实例 中 没有 作为 数组 声明 的 variant 也 可 以 表示 数组 。 除 了 长 度 固 定 的 字符 串 以 及 用 户 定义 类 型 之 外 ， 
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variant 变量 可 以 表示 任何 类 型 的 数组 。 尽管 一 个 包含 数组 的 variant 和 一 个 元 素 为 variant 类 型 的 数组 在 概念 上 有 
所 不 同 ， 但 对 数组 元 素 的 访问 方式 是 相同 的 。 


| 
高 级 | 
起 呆 林 才 ;二 wx 


力 实例 说 明 


目前 ， 日 期 型 数据 格式 有 多 种 ， 采 用 录入 方式 相对 来 说 比较 繁琐 ， 而 且 采 用 这 种 方式 也 不 利于 日 期 格式 的 
统一 ， 所 以 可 以 在 信息 录入 页 面 中 加 入 一 个 简单 的 日 期 选择 器 来 解决 上 述 问题 。 运 行 本 实例 ， 在 新 奥 家 电 连 锁 
后 台 管理 系统 的 销售 查询 页 面 中 ， 单 击 “ 售 货 日 期 ”文本 框 后 的 日 期 选择 按钮 ， 会 弹出 “日 期 选择 器 ”对 话 框 ， 
选择 售 货 日 期 的 起 始 日 期 后 ， 单 击 “ 确 定 ”按钮 ， 即 可 成 功 地 将 选择 的 日 期 添加 到 对 应 的 日 期 文本 框 中 ， 运 行 
结果 如 图 3.61 所 示 。 


Ny iit 


售 黄 期: ”从 轩 1065 到 i086 回 本 i 


本 日 期 选择 器 一 网 页 对 话机 区 


2oos 引 


图 3.61 日 期 选择 器 


图 关键 技术 


由 于 日 期 为 连续 的 数字 , 开发 网 页 时 将 这 些 信息 逐个 写 在 <option> 与 </option> 标 记 之 间 固然 可 行 , 但 这 样 会 
增加 程序 开发 时 间 ， 在 开发 本 实例 时 ， 笔 者 将 通过 PHP 的 循环 结构 显示 出 下 拉 列 表 框 中 的 连续 数据 ， 这 样 更 灵 
活 方便 ， 实 现 该 过 程 的 代码 如 下 : 


<form name="form2"> 
<tr bgcolor="#826650"> 
<td width="13"><div align="center"><a href="#" onClick="addday()"></a></div></td> 
<td width="80"> 
‘<select name="n1"> 


<?php 
for($i=2005:$i<=2050:$i++){ 
2> 
<option value=<?php echo $i:?>><?php echo $i:?></option> 
<?php 
> 
</select> 


年 <ltd> 
<td width="64"><select name="yl"> 


<?php 
for($i=1:$1<=12:$iH+){ 
?> 
<option value=<?php echo $i:?>><?php echo $i:?></option> 


<php 
} 
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> 
</sclect> 
月 <itd> 
<td width="77"><select name="r1"> 
<?php 
for(Si=1:$i<=31:SitH{ 
?> 


<option value=<?php echo $i:?>><?php echo $i:?></option> 
sphp 
1 
?> 
</select> 
日 <td> 
<td width="16"><div align="center"><a href="#" onClick="subdayO"></a></div></td> 
<lt> 
</form> 


设计 过 程 
(1) 在 父 窗口 中 创建 函数 open_day_from0 和 open_day_ to0， 实 现 子 窗口 的 弹出 和 父 窗口 与 子 窗口 之 间 的 
信息 传递 ， 代 码 如 下 : 


<table width="250" height="25" border="0" align="center' cellpadding="0" cellspacing: 
<form name="form2"> 
<tr bgcolor="#826650"> 
<td width="13"><div align="center"><a href="#" onClick="addday()"></a></div></td> 
<td width="80"> 
‘<select name="n1"> 
<?php 
for(Si=2005:$i<=2050:Sit+) { 


?> 


<option value=<?php echo $i:?>><?php echo $i:?></option> 
< 
?php 
} 


?> 
<lselect> 
年 <td> 
<td width=' 
<?php 
for($i=1;$i<=12;$i++) { 


?> 


"><select name="y1"> 


<option value=<?php echo $i:?>><?php echo $i:?></option> 
<?php 
?> 
</select> 
月 <htd> 
<td width="77"><select name="r1"> 
<?php 
for(Si=1:$i<=31:$itH) { 
?> 
<option value=<?php echo $i:?>><?php echo $i:?></option> 
<?php 
} 
> 
</select> 
HB</td> 
<td width="16"><div align="center"><a href="#" onClick="subdayO|"></a></div></td> 
<ltr> 
</form> 
</table> 
<table width="250" height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 
<a> 
<td bgcolor="#826650"><div align="center"><input type="button" onClick="close_day0" class="buttoncss" value=" 确 定 "></div></td> 
<lt> 
</table> 
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(2) 单 击 “确定 ”按钮 ， 调 用 close_day() 函 数 实现 日 期 的 传 值 ， 代 码 如 下 : 
<scriptlanguage="javascript> 
fonction close_dayO{ 
window.returnValue=document form2.n1.value+"-"+document form? .yl.value+"-"+document form2.r1.value; 
window.close(); 
} 


Jscript> 
图 秘 稚 心 ; 


心 法 领悟 205: JavaScript 弹出 窗口 。 


实现 窗口 之 间 的 信息 传递 主要 通过 window 的 showModalDialog0 方 法 实现 ， 其 语法 格式 如 下 : 
window.showModalDialog(' 弹 出 窗口 地 址 "弹出 窗口 名 称 ', "弹出 窗口 所 具有 的 属性 ) 


窗口 所 具有 的 属性 包括 窗口 的 高 度 、 宽 度 ， 以 及 窗口 是 否 有 地 址 栏 、 状 态 栏 、 滚 动 条 等 一 些 特性 。 


实例 206 趣味 指数 ， 宙 本 女 页 ， 
图 实例 说 明 


为 了 方便 用 户 浏览 网 页 信息 ， 可 以 将 网 页 信息 以 全 屏 显 示 的 网 页 模式 展示 给 用 户 ， 这 样 一 来 可 以 方便 用 户 
浏览 到 网 页 的 全 部 信息 ; 二 来 可 以 保证 用 户 查看 后 能 及 时 将 其 关闭 。 运 行 本 实例 ， 在 明日 科技 编程 词典 网 站 中 
单 击 “购买 须知 ” 超 链接 后 ， 将 弹出 如 图 3.62 所 示 的 购买 须知 页 面 ， 该 页 面 就 是 通过 全 屏 显示 的 网 页 模式 对 话 
框 ， 用 户 只 有 关闭 该 页 面 后 ， 才 可 以 查看 网 站 的 其 他 内 容 。 


友 编程 间 典 系列 版 本 及 价格 克 
和 @ Visaal Basic 护 得 间 典 
软件 版 本 功能 享受 服务 价格 (元 ) 
标准 版 | [8 一 年 两 次 升级 128 
开发 版 详 二 功能 。 | 每 月 升级 ， 每 月 归 送 最 新 软件 ， 编 程 训 。 全 年 提供 30 个 项 目 尖 程序 的 有 限 服务 支持 5 
二 版 说 二 能 。 | 每 月 升级 ， 和 月 参 送 晤 新 软件 ， 婉 程 术 赛 全 年 提供 60 个 项 目 源 查 序 的 有 限 服务 支持 。 1996 
企业 版 | 详细 功能 每 月 升级 ,每 月 赔 送 最 新 软件 ,编程 锦 宫 。 提 供 一 年 全 程 技术 支持 服务 。 | 6998 
罗 Delphi 编 程 词典 
软件 版 本 功能 享受 服务 价格 (元 ) 
| 标 从 版 训 和 动能。 | 一 年 丙 次 逢 组 128 
开发 上 证 让 。 | 每 月 天 婚 ， 每 月 参 送 是 新 软件 ， 纺 各 坟 塞 。 全 年 提供 20 个 项 目 尖 程序 的 有 限 服务 支持。 加 
专业 版 证 能 。 | 每 月 和 领 ， 年 月 震 关 晤 新 软件 ， 扩 程 赛 。 全 年 提供 90 个 项 目 尖 程序 的 有 限 服务 支持 1996 
| 做 详 绍 动能。 | 每 月 升 讨 ， 每 月 区 送 最 新 软件 ， 护 各 坟 覃 。 提供 一 年 全 程 技术 支持 服务 。 B00 


3.62 ”弹出 全 屏 显示 的 网 页 模式 对 话 框 


图 关键 技术 


本 实例 主要 应 用 screen 对 象 的 width 、height 属性 和 window 对 象 的 showModalDialog0 方 法 实现 ， 
showModalDialog0 方 法 用 于 弹出 全 屏 显示 的 网 页 模式 对 话 框 ， 其 语法 格式 如 下 : 


variant = object.showModalDialog(sURL [. vArguments [. sFeatures]]) 

参数 说 明 : 

sURL: 指定 URL 文件 地 址 。 

vArguments: 用 于 向 网 页 对 话 框 传递 参数 。 传 递 参数 的 类 型 不 受 限 制 ， 对 于 字符 串 类 型 ， 最 大 为 4096 个 字 
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符 ， 但 也 可 以 传递 对 象 ， 如 index.html。 
图 设计 过 程 
(1) 创建 提供 “购买 须知 ” 超 链接 的 页 面 ， 在 该 页 面 中 添加 空 的 超 链 接 ， 在 该 超 链接 的 onClick 事件 中 调 


用 自 定义 JavaScript 函数 opendialog0， 代 码 如 下 : 
有 ree onClick="opendialog0 吃 购买 须知 <ja> 


(2) 编写 自 定义 JavaScript 函数 opendialog0， 用 于 打开 全 屏 显 示 的 网 页 对 话 框 ， 代 码 如 下 : 
<script language 一 javascript > 


var height=screen.height: 

window.showModalDialog("notice.php","","dialogWidth="+width+"px:dialogHeight="+height+ "px:status=no:help=no:scrollbars=no") 
} 

</script> 


国 秘笈 心 法 
心 法 领悟 206: showModalDialog0 与 showModelessDialog0 的 区 别 是 什么 。 


二 者 的 区 别 在 于 showModalDialog0 打 开 的 网 页 对 话 框 为 模式 窗口 ， 置 于 父 窗 口上 ， 必 须 关 闭 才能 访问 父 窗 
口 ， 而 showModelessDialog0 打 开 的 对 话 框 是 无 模式 窗口 ， 打 开 后 不 必 关 闭 也 可 以 访问 父 窗口 或 其 他 窗口 。 


Ee es i i ee | 


图 实例 说 明 


通常 情况 下 ， 当 使 用 JavaScript 的 window.close() 语 句 关闭 IE 主 窗口 时 , 会 弹出 一 个 “您 查看 的 网 页 正在 试 
图 关闭 窗口 。 是 否 关 闭 此 窗口 ? ”的 询问 对 话 框 。 在 制作 网 络 应 用 程序 时 ， 这 种 情况 是 用 户 不 想 看 到 的 ， 那 么 
如 何 才能 屏蔽 该 对 话 框 呢 ? 本 实例 将 介绍 解决 该 问题 的 方法 。 运 行 本 实例 ， 效 果 如 图 3.63 所 示 ， 单 击 “ 关 闭 窗 
口 ” 超 链 接 后 ， 该 正 窗口 将 被 直接 关闭 。 


QQ 编 夸 司 典 


oer ane Midst e a ak hts sai 
全 术 过 和 在 你 开 发 的 记 用 ， 快 提 太 得 水 


每 个 函数 均 提供 了 大 量 示例 和 奥 


全 的 项 上 


人 遇 新 89 西数 应 用 1 《PIF 编程 词典 ) 软件 开发 版 以 上 
和 
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图 3.63 关闭 窗口 不 弹出 对 话 框 


力 关键 技术 


本 实例 主要 应 用 window 对 象 的 opener 属性 将 要 关闭 的 正 窗口 的 打开 窗口 设置 为 null, 然后 再 通过 window 
对 象 的 close( 方 法 将 该 窗口 关闭 ， 这 样 就 不 会 弹出 询问 对 话 框 。 


图 设计 过 程 
创建 ndex php 文件 ， 添 加 一 个 用 于 关闭 窗口 的 超 链接 ， 在 该 超 链接 的 onClick 事件 中 添加 控制 窗口 关闭 的 


第 3 章 Web 页 面 交 互 
代码 如 下 : 


<a href="#" onClick="window.opener=null:window.close0:"> 。 关闭 窗口 </a> 


心 法 领悟 207: 详解 opener。 
opener 是 一 个 可 读 可 写 的 属性 ， 对 一 个 window 对 象 返回 一 个 引用 ， 用 于 指定 打开 本 窗口 的 窗口 对 象 ， 语 


opener 属性 返回 的 是 一 个 窗口 对 象 ， 其 与 打开 该 窗口 的 父 窗口 相 联 系 ， 当 访问 子 窗口 的 opener 属性 时 ， 返 
回 的 是 父 窗口 。 通 过 该 属性 ， 可 以 使 用 父 窗口 对 象 中 的 方法 和 属性 。 


= spe 


趣味 指数 : 依依 颂 育 | 


力 实例 说 明 


在 网 站 开发 过 程 中 ， 需 要 考虑 网 站 的 安全 性 ， 例 如 ， 设 置 允许 哪些 用 户 访问 是 一 项 非常 重要 的 技术 。 本 实 
例 在 页 面 中 设置 一 个 访问 权限 ， 判 断 用 户 是 否 可 以 访问 该 网 页 。 如 果 用 户 名 和 密码 不 正确 就 不 可 以 访问 ， 并 弹 
出 提示 对 话 框 重 定向 到 该 网 页 ， 运 行 结果 如 图 3.64 所 示 。 


留言 人 : 
Email : 
E| 
全 言 内 容 : A managEeAn 
习 
| | 


3.64 ”弹出 提示 对 话 框 并 重 定向 网 页 


图 关键 技术 


本 实例 主要 将 PHP 与 JavaScript 相 结合 , 通过 JavaScript 脚 本 来 弹出 对 话 框 信息 ,应 用 window 对 象 中 的 alert0 


方法 和 窗口 属性 location 实现 此 功能 ， 语 法 格式 如 下 : 
alert (弹出 对 话 框 的 内 容 ); 
window.location hre 全 :重新 定向 的 页 面 : 


参数 说 明 : 
alert0: 弹出 一 个 警告 对 话 框 。 


PHP 开发 实例 大 全 (基础 卷 ) 
location: 定位 区 ， 也 叫 地 址 栏 ， 是 可 以 输入 URL 的 浏览 器 文本 区 。 
力 设计 过 程 
弹出 提示 对 话 框 并 重 定向 网 页 文件 的 关键 代码 如 下 : 


<?php session start();?> 
<title> 弹 出 提示 对 话 框 并 重 定向 网 页 <ltle> 


php 

这 $gly 一 tue && Smima=—true){ 

这 Sljid 一 tmuejf 

$lid-$_GET[liid]; 

echo "这 就 是 弹出 提示 对 话 框 并 重 定向 网 页 !":} 


?> 


<?php }else{ 
echo "<script>alert (这 就 是 弹出 提示 对 话 框 并 重 定向 网 页 !); window location hre 人 admin php':</script>"; 
} 


国 秘笈 心 法 
心 法 领悟 208: 浅 谈 网 页 重 定向 。 
这 里 的 网 页 重 定向 与 PHP 判断 用 户 登 录 权限 页 相似 ， 都 是 网 页 的 一 种 跳 转 方法 。 


力 实例 说 明 


进入 网 站 后 ， 很 多 网 站 都 会 弹出 一 个 新 窗口 (如 广告 等 ) ， 多 数 窗口 需要 浏览 者 自行 关闭 。 为 了 方便 浏览 
者 对 页 面 中 信息 的 浏览 ， 本 实例 运用 一 种 新 的 方法 来 解决 弹出 窗口 关闭 这 一 问题 。 当 浏览 者 进入 某 网 站 进行 济 
览 时 ， 无 须 关 闭 弹 出 的 新 窗口 ， 在 页 面 运行 超过 一 定 的 时 间 之 后 ， 该 窗口 将 自动 关闭 ， 这 样 将 大 大 方便 浏览 者 
的 浏览 。 运 行 本 实例 ， 将 弹出 一 个 新 窗口 显示 广告 信息 ， 如 图 3.65 所 示 ， 该 广告 窗口 在 页 面 运行 5 秒 钟 后 自动 
关闭 。 


六 中 相 归 食 食 让 让 


图 3.65 自动 关闭 的 广告 窗口 


图 关键 技术 
本 实例 主要 应 用 window 对 象 的 setTimeout0 方 法 ， 实 现 延 迟 执行 某 一 操作 。window 对 象 的 setTimeout() 方 


法 的 语法 格式 如 下 : 
setTimeout(expression.secdelay[ .language]) 


pa 


辣 
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参数 说 明 : 

expression: 是 一 个 字符 串 ， 可 包含 任何 对 函数 、 方 法 或 者 单个 JavaScript 语句 的 调用 。 

secdelay: 指定 运行 间隔 的 时 间 ， 以 毫秒 为 单位 。 

language: 指定 语句 或 参数 expression 调用 的 函数 所 使 用 的 脚本 语言 。 如 果 完 全 使 用 JavaScript， 则 不 需 设 
置 该 参数 。 


力 设计 过 程 


(1) 通过 JavaScript 脚本 实现 打开 新 窗口 功能 ， 代 码 如 下 : 
‘<script language 一 " Hasan 
window.open("new.htm", "new", "height=135,width=180,top=10.1eft=20"); 
</script> 


(2) 通过 设置 window 对 象 的 setTimeout0 方 法 ， 实 现 弹出 新 窗口 的 自动 关闭 ， 代 码 如 下 : 
EE 


| | 秘笈 心 ; 


心 法 领悟 209: 秒 与 毫秒 。 
如 果 用 户 不 是 运动 员 ， 很 少 能 接触 到 毫秒 这 个 单位 ， 但 是 在 计算 机 领域 中 ， 毫 秒 是 经 常 被 用 到 的 。 秒 与 毫 
秒 的 换算 比例 是 1:1000， 也 就 是 说 1 秒 等 于 1000 毫秒 。 


实例 210 


高 级 : 
趣味 指数 : holoiodl 


力 实例 说 明 


在 论坛 、 博 客 等 注册 页 面 添加 头像 选择 功能 ， 可 以 增加 网 页 活力 。 运 行 本 实例 ， 首 先 单 击 图 3.66 中 的 “ 头 
像 选 择 ” 超 链接 ， 在 弹出 的 窗口 中 选择 自己 喜爱 的 头像 后 ， 弹 出 窗口 将 自动 关闭 ， 注 册页 面 中 的 头像 变 成 用 户 
所 选择 的 头像 。 


日 用 户 注册 
用 户 昵称 : 
注册 密码 : 
E-mail; *# 请 第 入 真实 的 E-mail 地 址 
真实 姓名 
职 业 : 天 司 。 
“a 息 
[| 
的 号 码 : 
联系 电话 : vv | 
ED 


3.66 ”选择 头像 


图 关键 技术 


本 实例 通过 调用 window 对 象 的 showModalDialog( 方 法 弹出 一 个 窗口 ， 当 用 户 单 击 某 个 头像 后 ， 将 该 头像 
对 应 的 数值 传递 给 父 窗 口 ， 父 窗口 通过 传递 过 来 的 数值 指定 用 户 所 选择 的 头像 。 
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四 设计 过 程 


(1) 首先 在 窗口 中 添加 “头像 选择 ” 超 链 接 ， 以 便 调用 select_face0 函 数 实现 窗口 的 弹出 功能 ， 代 码 如 下 : 
[<a href="#" onclick="select face0" class="a1"> 头 像 选择 </a>] 


(2) 利 用 JavaScript 编写 select face0O) 函 数 , 实现 头像 选择 窗口 的 弹出 以 及 返回 用 户 所 选择 头像 对 应 的 数值 ， 
代码 如 下 : 


<script language="javascript"> 
function select_faceO{ 
var somevalue; 
somevalue=window.showModalDialog("browse.php"." 请 选择 您 喜欢 的 人 物 头像", "dialogWidth='310px':dialogHeight='240px':status='no:help='no'; 
scrollbars='no™"); 
document form regist.user sre.sre="images/head/"+somevalue+".gif"; 
} 
<lscript> 
(3) 在 弹出 的 窗口 中 通过 selectface0 函 数 返回 用 户 所 选择 头像 对 应 的 数值 ， 代 码 如 下 : 
<script language="javascript"> 
function selectface(ICQ){ 
windowxretumValue=ICQ: 
window.close(); 


} 
</script> 
图 秘笈 心 法 


心 法 领悟 210: showModalDialog0 方 法 详解 。 
window.showModalDialog( 弹出 窗口 地 址 ' 弹出 窗口 名 称 ' ' 弹 出 窗口 所 具有 的 属性 ) 


窗口 所 具有 的 属性 包括 窗口 的 高 度 、 宽 度 ， 以 及 窗口 是 否 有 地 址 栏 、 状 态 栏 、 滚 动 条 等 一 些 特性 。 


实例 211 


实例 说 明 


网 络 不 仅 是 信息 的 海洋 ， 也 是 广告 的 海洋 。 除 了 普通 的 gif 和 flash 之 外 ， 浮 动 广告 也 是 时 下 网 上 较为 流行 
的 广告 形式 之 一 ， 当 拖 抱 浏览 器 的 滚动 条 时 ， 这 种 页 面 上 浮动 的 广告 ， 可 以 跟随 屏幕 一 起 移动 ， 这 种 效果 对 于 
广告 展示 有 相当 大 的 实用 价值 。 本 实例 将 制作 一 个 浮动 的 广告 窗口 ， 运 行 结果 如 图 3.67 所 示 。 


一 一 
图 书 调查 显示 结果 


工 。 您 经 党 购买 的 编程 基 图 书展 于 帮 一 夫 ? 


开发 手册 三 百 例 三 技巧 三 实例 入 锦 厂 教程 
称 全 用 下 面 时 入 近 各 语言 或 工具 ? 


Tw Tw Tw TJ Tym Tr 厂 XE 


了 您 晤 可 意 购 开 或 借 同 攻关 图 7 
厂 入 放 $3 厂 讲解 ! 实 订 。 厂 三 全 空间 厂 百 鲁 型 三 技巧 型 
E24 


图 3.67 浮动 的 广告 窗口 
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力 关键 技术 


本 实例 主要 应 用 DIV 层 制作 浮动 广告 ,然后 应 用 documentwrite() 方 法 输出 DIV 层 。documentwrite() 方 法 的 
语法 格式 如 下 : 

document.write(value,...) 

参数 说 明 : 

value: 要 添加 到 document 的 任意 一 个 JavaScript 值 。 如 果 该 值 不 是 字符 串 ， 那 么 在 被 添加 至 文档 之 前 ， 会 
被 转化 成 一 个 字符 串 。 

.…: 任意 多 个 〈0 个 或 多 个 ) 要 依次) 写 入 文档 的 值 。 


力 设计 过 程 
(1) 在 网 站 首页 引入 JavaScript 脚本 文件 ， 代 码 如 下 : 


<SCRIPT language=JavaScript sre="js/leftjs"></SCRIPT> 


(2) 运用 JavaScript 脚本 自 定义 函数 ， 控 制 浮动 广告 的 位 置 及 其 相关 属性 ， 代 码 如 下 : 
var adve=0.15 
var collection; 
function motion0 { 
this.items= []; 
this.addItem= function(id,x,y,content){ 
document write(<DIV id="+id+' style="Z-INDEX: 10; POSITION: absolute width:80px; 
+(typeof(x)=='string'?eval(x):x)+':top:'+(typeof(y)=—='string'?eval(y):y)+">"+content+"</DIV>"); 


Var newltem= {}; 
newltem.object= document.getElementById(id); 
newltem.x= x; 

newltem.y=y; 

this.items[this.items.length]= newItem: 


8 
this.play=function(){ 
collection=this.items 
setInterval('playO',10); 

} 
} 
function play0 { 
for(var i=0;i<collection.length:i++) { 
var followOb= collection[i].object: 
varfollowObj x =(typeof(collection[i].x)=='string'?eval(collection[i].x):collection[i].x); 
var followObj_y= (typeof(collection[i].y)=='string'?eval(collection[i].y):collection[i].y); 
if(followObj.offsetLeft!=(document.body.scrollLeft+followObj x)) { 
Var dx=(document.body.scrollLeft+followObj_x-followObj.offsetLeft)*adve: 
dx=(dx>071:-1)*Math.ceil(Math.abs(dx)); 
followObi.style.lefi=followObj.offsetLeft+dx: 
} 
if(followObj.offsetTop!=(document.body.scrollTop+followObj_y)) { 
var dy=(documentbody.scrollTop+followObj_y-followObij.offsetTop)*adve: 
dy=(dy>0?1:-1)*Math.ceil(Math.abs(dy)); 
followObi.style.top=followObj.offsetTop+dy: 


} 
followObj.style.display =": 
} 


var themotion= new motion(): 

themotion.addItem('followDiv1',200,200,'<a hre 人 ="http://wpa.qq.com/msgrd?V=1&Uin=228691050&Site= 在 线 咨询 &Menu=no" title=" 在 线 即 时 交谈 
"><img sre=./images/qqhelp.gif height=70 width="80" border=0></a>): 

themotion.playO: 


力 秘笈 心 法 


心 法 领悟 211: 使 用 document .write() 方 法 的 注意 事项 。 
调用 document.write0 方 法 的 结果 也 许 不 能 立刻 在 目标 浏览 器 窗口 中 显示 出 来 ， 这 是 因为 浏览 器 可 能 会 将 数 
据 缓存 起 来 ， 以 便 形 成 大 的 数据 块 输出 。 
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实例 212 


力 实例 说 明 


广告 作为 网 站 最 大 的 盈利 手段 ， 任 何 网 站 都 不 可 能 将 其 省 略 ， 那 么 ， 如 何 才能 实现 网 站 既 可 以 从 广告 中 获 
利 ， 又 能 使 用 户 流畅 地 阅读 网 站 信息 呢 ? 本 实例 将 介绍 如 何 制作 一 个 从 首页 右 下 角 弹 出 的 渐 显 广告 窗 体 ， 该 窗 
体 在 用 户 登录 网 站 时 自动 从 右 下 角 渐 渐 弹 出 ， 然 后 由 用 户 手动 关闭 。 本 实例 的 运行 结果 如 图 3.68 所 示 。 


| 


CW 编程 者 之 家 


忽 明 日 科技 服务 热线 : (04314978981 4978982 Email : 。 页 sual Basic 顷 生词 典 Delphi 注 得 语 册 ”三 ? 旦 程 启 秽 AsF Wet 闹 程 辣 风 FP 遇 程 疗 且 


和 明日 科技 向 您 推荐 


技术 支 圭 。。 会 员 中 心 。 软件 下 


图 3.68 右 下 角 渐 显 广告 


图 关键 技术 


本 实例 主要 应 用 JavaScript 脚本 的 window 对 象 ，window 对 象 主要 用 于 在 HTML 中 打开 窗口 ， 应 用 极为 普 
遍 ， 但 也 有 一 些 缺陷 。 用户 浏览 器 决定 窗口 的 外 观 ， 设计 者 左右 不 了 其 窗口 的 大 小 及 样式 , 但 JavaScript 给 了 程 
序 这 种 控制 权 。 在 JavaScript 中 ， 可 以 使 用 window 对 象 来 实现 对 窗口 的 控制 。 


图 设计 过 程 
本 实例 主要 应 用 window 对 象 的 open0 方 法 打开 一 个 在 首页 右 下 角 弹 出 渐 显 的 广告 窗口 ,在 网 站 首页 中 添加 
如 下 代码 : 


<script language="javascript"> 
var newformW=300; 


i .open("advertise. ht "."width="+newformW+",height="+newformH+",top="+T+",left="+IL); 
} 


PPO: 
</script> 
力 秘笈 心 法 
心 法 领悟 212: window 对 象 打开 窗口 详解 。 
使 用 window 对 象 打开 窗口 的 语法 格式 如 下 : 
windowVar=window.open(url.windowname[.location]): 
参数 说 明 : 
windowVar: 当前 打开 窗口 的 句柄 。 如 果 open0 方 法 成 功 ， 则 windowVar 的 值 为 一 个 window 对 象 的 句柄 ， 


Bs 
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否则 windowVar 的 值 是 一 个 空 值 。 

wl: 目标 窗口 的 URL。 如 果 URL 是 一 个 空 字符 串 ， 则 浏览 器 将 打开 一 个 空白 窗口 ， 允 许 用 write0 方 法 创 
建 动态 HIML。 

windowname: window 对 象 的 名 称 。 

location: 对 窗口 属性 进行 设置 。 


3.7 状态 栏 设 计 


不 论 是 在 应 用 程序 还 是 在 网 页 中 都 会 应 用 到 状态 栏 ， 状 态 栏 可 为 用 户 提供 一 些 提示 信息 ， 如 当前 系统 的 日 
期 和 时 间 、 软 件 版 本 、 链 接地 址 、 系 统 信息 以 及 一 些 自 定义 信息 等 。 


力 实例 说 明 


浏览 网 页 时 ， 用 户 往往 更 加 注意 网 站 页 面 的 内 容 ， 而 不 会 过 多 注意 状态 栏 ， 如 果 为 页 面 的 状态 栏 添加 一 
些 特效 ， 一 定 会 给 网 站 增添 一 道 亮丽 的 风景 。 本 实例 实现 在 状态 栏 中 显示 跑马 灯 特效 文字 ， 运 行 结 果 如 图 3.69 
所 示 。 
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今天 时 0o7 年 2 月 1 日、 居 有 四。 。 一 修 的 当 疹 位置 : 公司 首页 》 图 书 介绍 》JS 玫 | 
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局 特 上 书 共 汪 关 注 | 


鞭 和 
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次 好 t 欢 加 沪 问 旺 巨 和 扶 图 书 同 站 客服 热 酉 : 0431-B49T8981 .| © 网 
3.69 跑马 灯 文 字 


力 关键 技术 


本 实例 主要 应 用 JavaScript 脚本 的 window 对 象 的 status 属性 ， 并 通过 编写 自 定义 函数 设置 状态 栏 中 的 文字 
及 文字 属性 ， 通 过 站 ..else.…. 条 件 语 句 控制 文字 的 循环 显示 效果 。 
最 后 ， 在 <body> 标 记 中 调用 该 函数 ， 从 而 实现 状态 栏 中 的 跑马 灯 文 字 特效 。 
图 设计 过 程 
(1) 利用 JavaScript 脚本 编写 自 定义 函数 ， 生 成 状态 栏 中 的 文字 及 文字 属性 ， 代 码 如 下 : 
i 


Mit(s){ 
var text=" 您 好 ! 欢迎 访问 明日 科技 图 书 网 站 。 客 服 热线 : 0431-84978981" 


var 
(>210){ 
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out="scrollit("+s+")"; 
var timer Two=window.setTimeout(out,200); 


} 

clseif(s <=210&&s>0){ 
for (i=0;i<s:iH+){ 
Printtext+=" "; 


timerTwo=window.: i 


} 

elseif (s <=0){ 

f(s < textlength){ 
Printtext+=text.substring(-s,text.length); 


a et 
out="scrollit("+s+")"; 
timerTwo=window.setTimeout(out,200); 


timerTwo=window.setTimeout("serollit(100)".200): 
} 
} 


} 
</SCRIPT> 


(2) 在 <body> 标 记 中 调用 自 定义 的 函数 。 


<body onLoad="scrollit(100):"> 


国 秘笈 心 法 


心 法 领悟 213: window 对 象 的 status 属性 详解 。 


window 对 象 的 status 属性 的 语法 格式 如 下 : 
window.status 


status 属性 是 一 个 可 读 可 写 的 字符 串 ， 声 明 浏览 器 状态 栏 的 当前 内 容 。 
高 级 上 
实 斧 
实例 趣味 指数 : 裕 廊 全 本 
国 实例 说 明 


为 了 在 节省 网 页 空间 的 同时 更 好 地 服务 于 广大 的 用 户 ， 可 以 将 网 站 要 显示 的 简短 的 广告 信息 显示 在 状态 栏 
中 。 运 行 本 实例 ， 在 状态 栏 中 收缩 显示 明日 科技 公司 的 网 址 和 客服 热线 ， 运 行 结果 如 图 3.70 所 示 。 
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3.70 ”收缩 显示 文字 
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图 关键 技术 


本 实例 主要 应 用 window 对 象 的 status 属性 。 当 显 示 的 文字 总 长 度 等 于 该 文本 的 长 度 时 , 再 反方 向 滚动 文字 ， 
从 而 实现 在 状态 栏 中 收缩 显示 文字 。 


window 对 象 的 status 属性 的 语法 格式 如 下 : 

window.status 

属性 status 是 一 个 可 读 可 写 的 字符 串 ， 声 明了 浏览 器 状态 栏 的 当前 内 容 。 
图 设计 过 程 

本 实例 主要 通过 JavaScript 脚本 编写 状态 栏 中 收缩 显示 文字 特效 的 自 定义 函数 ， 完 整 代码 如 下 : 

<Script language=JavaScript> 

var text1=" 欢 迎 访 问 明日 科技 主页 ，www.mingrisoft.com"; 

comeback=0; 

cometo=0; 

window. status=text1.substring(0,cometo); 

1 


Someto--: 
ese 0) (eee 
else {cometot+:if(cometo—text] .Jength) {comeback=1}} 
window.status=text1.substring(0,cometo)+"( 客 服 热 线 : 0431-84978981)"; 
if(cometo=—textl length) {window.setTimeout("dis()",1000)} 
else {window.setTimeout("disO",50)} 
} 
dis(); 
</Seript> 
图 秘笈 心 法 
心 法 领悟 214: 状态 栏 。 
状态 栏 只 是 起 到 一 个 类 似 于 广告 的 作用 ， 但 它 比 其 他 的 弹出 层 广告 逊色 一 些 。 


2 | 


力 实例 说 明 


在 状态 栏 中 显示 数字 时 钟 是 个 性 化 网 站 所 特有 的 功能 ， 它 不 仅 可 以 节约 网 页 空间 ， 而 且 可 以 方便 用 户 时 时 
查看 。 本 实例 实现 在 状态 栏 中 显示 一 个 24 小 时 制 的 数字 时 钟 ， 运 行 结果 如 图 3.71 所 示 。 


有 
| Oi 有 


可 
册 拓 亲本 本 
图 3.71 状态 栏 显示 时 钟 
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图 关键 技术 


本 实例 主要 应 用 window 对 象 的 status 属性 实现 在 状态 栏 中 显示 数字 时 钟 ， 详 细 讲解 请 参考 实例 214。 


力 设计 过 程 


(1) 本 实例 主要 通过 JavaScript 脚本 开发 状态 栏 中 显示 动态 数字 时 钟 的 自 定义 函数 ， 代 码 如 下 : 


<script language="JavaScript"> 
var timerID = pull; 
var timerRunning = false; 


function stopelock Of 
f(t 


clearTimeout(timerID): 
timerRunning = false; 
} 


function showtime | { 
var now = new Date(); 
var hours = now.getHours(); 
var minutes = now.getMinutes(); 
var seconds = now.ge! 


var timeValue = "北京 时 间 : "+ ((hours >24) ? hours -24 :hours) 
ca 


timeValue += ((minutes < 10)? 
timeValue += ((seconds < 10) ? ":0" : ":" 
window.status = timeValue: 

timerID = setTimeout("showtimeO".1000): 
timerRunning = true; 


} 

fanction startclock 0 { 
stopclock(); 
这 


} 
</script> 


(2) 在 <body> 标 记 中 调用 自 定义 函数 startclock0， 代 码 如 下 : 


<body onLoad="startclock()"> 


力 秘笈 心 法 
心 法 领悟 215: JavaScript 脚本 中 时 间 的 设置 。 


在 JavaScript 脚本 中 设置 日 期 和 时 间 ， 首 先 要 实例 化 Date 类 ， 然 后 调用 其 中 的 方法 ， 获 取 对 应 的 日 期 、 时 


间 值 。 


3.8 导航 菜单 设计 


网 站 导航 菜单 对 于 每 个 网 站 都 是 必 不 可 少 的 ， 


它 相 当 于 城市 中 的 路 标 ， 可 以 指引 浏览 者 找到 自己 热衷 的 内 


容 。 导 航 菜单 有 很 多 种 ， 如 本 节 中 介绍 的 带 图 标的 文字 导航 条 、Flash 导航 条 、 按 钮 导航 条 、 弹 出 式 下 拉 菜 单 、 


二 级 导航 菜单 、 树 状 菜单 等 。 


图 实例 说 明 


OO 网 


高 级 | 
趣味 指教 : ododod| 


树 形 结构 能 够 以 层次 形式 展示 信息 ， 用 它 来 描述 具有 上 下 级 关系 的 内 容 再 恰当 不 过 。 本 实例 利用 菜单 的 树 
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形 结构 来 描述 企业 的 人 事 组 织 架构 ， 效 果 如 图 3.72 所 示 。 


图 3.72 树 形 导航 菜单 


图 关键 技术 


本 实例 中 实现 菜单 的 树 形 显示 是 通过 <table> 标 签 结合 DIV 实现 的 。 父 节点 利用 表格 来 显示 ， 子 节点 利用 
DIV 媒 套 表格 来 实现 。 这 样 做 的 目的 是 容易 对 子 节点 的 显示 和 隐藏 进行 控制 。 例 如 ， 当 用 户 单 击 父 节 点 时 ， 如 
果子 节点 没有 展开 , 将 DIV 设置 为 可 见 就 可 以 显示 子 节点 ; 如 果子 节点 可 见 , 将 DIV 设置 为 不 可 见 就 可 以 隐藏 
子 节 点 。 


图 设计 过 程 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 


(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 2 行 1 列 的 表格 ,在 表格 的 第 2 行 再 添加 一 个 2 行 2 列 的 表格 。 表 
格 的 第 1 列 用 于 显示 节点 前 的 图 标 ， 第 2 列 描述 节点 文本 ， 主 要 代码 如 下 : 


<form id="forml" name="form1" method="post" action=" > 
<table width="372" border="1" align="center” © bgcolor="#E6F2F2" bordercolor="#478DSD" 
style="border-style:none" cellspacing="0" > 
<tr> 
<td scope="col" align="center" style="border-bottom-style:none" > 人 事 组 织 架构 <ltd> 


</tr> 
<tr> 
<td> 
<table width="100%" border="0" cellpadding="0" cellspacing="0" align="left"> 
<?php / 赔 入 PHP 脚本 
Sxml file = simplexml load_file("org.xml"); /1/ 从 XML 文件 中 加 载 节点 
foreach($xml_file->children() as Snode){ // 遍 历 根 节点 
?> 
<t> 
<td width="38%" align="right"> /设置 节点 图 标 
<img sre="images/rootnode.gif" width="15" height="15" border-"0"> </img> 
<htd> 
<td width="62%" left="0px" align="left" ><a href="#" onclick= "ShowNode(<?php echo $node ?>)">&nbsp:&nbsp:; 
<?php echo $node ?></a> // 设 置 节点 文本 
<htd> 
</tr> 
<t> 


<td width ="38%" align="center" > 
<itd> 


<td width ="62%" > 
<div id= <?php echo $node ?> style ="display:none" class="HideDiv" > // 定 义 DIV 
<table width="100%" border="0" cellpadding="0" cellspacing="0" align="left" > 
<?1 


foreach($node->childrenO) as Svalue){ /遍历 子 节点 
?> 


<t> 
<td width ="10%" align="right" > 
<img sre="images/childnode.gif’ width="15" height="15" border="0" > </img> 

<ftd> 

<td width="90%" align="left ><a href-"#" >&nbsp:&nbsp:<2php echo $value?></a> 
<ftd> 

</> 

<?php 
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<div> 
<hd> 
</r> 
<?php 
} 
?> 
</table> 
<htd> 
</> 
</table> 
<script language="javascript"> 
function ShowNode(ParentID) { /隐藏 或 显示 子 节点 


var Div = ParentID; 
if (Div.style.display — "none"){ 

Div.style.display = "block"; // 显 示 DIV， 以 此 来 显示 子 节点 
jelse if (Div.style.display 一 "block"){ 

Div.style.display = "none"; /隐藏 DIV， 间 接 隐 藏 子 节点 


(3) 人 事 组 织 的 架构 存储 于 XML 文件 org.xml 中 。 
图 秘笈 心 法 


心 法 领悟 216， 动态 设置 超 链接 。 
在 设计 网 站 项 目 时 ， 有 时 需要 根据 实际 情况 动态 设置 超 链 接 的 内 容 。 在 利用 <a> 标 签 定义 超 链接 时 可 以 结合 


PHP 脚本 来 实现 这 一 功能 ， 例 如 : 
<a href="#" onclick= "ShowNode(<?php echo $node ?>)">&nbsp:&nbsp; <?php echo Snode ?></a> 


趣味 指数 : 请 寅 良 请 | 


力 实例 说 明 


在 网 站 中 不 仅 可 以 设置 导航 条 ， 而 且 还 可 以 设置 导航 菜单 。 由 于 菜单 内 容 比较 多 ， 在 同一 页 面 中 显示 会 比 
较 杂 乱 ， 所 以 目前 多 数 设计 者 都 采用 收缩 式 的 导航 菜单 。 运 行 本 实例 ， 当 浏览 者 单 击 “ 网 站 管理 ”时 ， 在 其 下 
方 将 弹出 导航 菜单 ， 如 图 3.73 所 示 ， 浏 览 者 再 次 单 击 “ 网 站 管理 ”时 ， 导 航 菜单 又 收缩 回去 ， 页 面 中 不 再 显示 
菜单 中 的 内 容 。 


~ 
人 功 双亲 单 


后 台 管理 首页 /退出 < 


同 站 管理 Q 
初始 化 信息 
服务 器 信息 


3.73 ”收缩 式 菜单 


图 关键 技术 


本 实例 主要 是 利用 显示 、 隐 藏 表格 来 实现 收缩 式 导航 菜单 的 功能 。 单 击 导航 菜单 ， 显 示 当前 菜单 的 内 容 ， 
隐藏 上 一 个 显示 的 菜单 。 在 隐藏 菜单 时 ， 让 其 有 规律 地 隐藏 进而 实现 动画 效果 。 
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四 设计 过 程 


(1) 显示 菜单 的 自 定义 函数 ， 代 码 如 下 : 
<SCRIPT language=javascript> 
fanction show(obj.maxg,0bj2){ 
if(obj.style.pixelHeight<maxg) { 
obj.style pixelHeight+=maxg/10; 
obi filters.alpha.opacity+=20; 
obj2.background="images /title_hide.gif’; 
iobj.style pixelHeight 一 maxg/10) 
obj.style.display="block’; 
myObij=obi; 


myObj2=obj2; 
setTimeout(show(myObj.mymaxgmyObj2).57: 
} 


} 
</SCRIPT> 


(2) 隐藏 菜单 的 自 定义 函数 ， 代 码 如 下 : 
<SCRIPT language=javascript> 
function hide(objmaxg,obj2){ 
if(obi.style.pixelHeight>0) { 
if(obj.style.pixelHeight—maxg/5) 
obj.style.display='none'; 
obj.style.pixelHeight-=maxg/S; 
obi filters.alpha.opacity-=10; 
obj2.background="images/title_show.gif"; 
myObj=obj; 
mymaxg—maxg 
myObj2=obj2; 
setTimeout(hide(myObjmymaxgmyObj2).57): 
} 


else 
if(whichContinue) 
whichContinue.click(); 


Di 
(3) 单 击 菜单 上 的 文字 时 ， 隐 藏 前 一 个 菜单 ， 显 示 当 前 菜单 ， 代 码 如 下 : 
<SCRIPT language=javascript> 
function chang(obi,maxg.obi2){ 
if(obj.style.pixelHeight) { 
hide(objmaxg.obj2); 


else 
这 mopen){ 
whichContinue=obj2; 
nopen click(: 


clse{ 
show(objmaxg.obj2): 
nopen=obi2: 
whichContinue="; 
} 
} 
</SCRIPT> 
(4) 在 表格 的 相关 鼠标 事件 中 调用 自 定义 的 方法 和 属性 来 改变 收缩 菜单 的 显示 和 隐藏 ， 代 码 如 下 : 
<TD class=list_title id-listl «onmouseover="this.typename=list_title2':” ©onclick=chang(menu1.60,listl): onmouseout="this.typename="ist_title';" 
background="images/title_hide.gif” height=25><SPAN> 网 站 管理 </SPAN> </TD> 


心 法 领 司 217: 收缩 式 导航 菜单 。 


275 


PHP 开发 实例 大 全 (基础 卷 ) 
收缩 式 导航 菜单 是 笔者 最 喜欢 的 导航 菜单 ,虽然 只 是 由 一 些 JavaScript 事件 组 成 , 但 是 操作 时 的 动态 效果 


| 
高 级 | 
起 呆 林 才 ! 南 页 宽 wx 


力 实例 说 明 


对 于 一 个 企业 网 站 来 说 ，“ 联 系 我 们 ”导航 条 是 必 不 可 少 的 。 为 了 更 加 引 人 注 意 ， 可 以 将 其 制作 成 具有 展 
开 式 动画 效果 的 导航 条 。 运 行 本 实例 ， 可 以 看 到 页 面 右 侧 的 “联系 我 们 ”导航 条 是 逐渐 展开 的 ， 并 且 每 次 刷新 
页 面 时 ， 都 会 以 同样 的 动画 效果 展开 ， 展 开 效 果 如 图 3.74 所 示 。 


图 3.74 展开 式 导航 条 


力 关键 技术 


本 实例 主要 是 通过 自 定义 JavaScript 函数 控制 图 片 (image) 对 象 的 height 属性 值 实现 的 。 为 了 实现 动画 效 
果 ， 在 JavaScript 函数 中 还 需要 应 用 setTimeout( 方 法 延迟 执行 改变 图 片 高 度 的 操作 。 


图 设计 过 程 
(1) 在 网 页 中 显示 “联系 我 们 ”导航 条 的 位 置 插入 一 张 全 部 展开 后 的 “联系 我 们 ”导航 图 片 ， 在 需要 设置 
超 链接 的 文字 上 添加 图 片 热点 并 设置 相应 的 超 链接 。 


(2) 将 图 片 的 height 属性 值 设 置 为 0，name 属性 设置 为 our。 
(3) 编写 自 定 义 的 JavaScript 函数 ourmove0， 用 于 实现 图 片 的 展开 效果 。ourmoveO 函 数 的 代码 如 下 : 


<script language="javascript"> 

function ourmoveO{ 

if(our height<163){ 
‘our.height=our.height+3 
setTimeout(ourmove.1) 

} 


</script> 
(4) 在 当前 页 面 的 最 底部 也 就 是 </body> 标 记 之 前 ， 添 加 如 下 代码 实现 导航 条 的 展开 式 动画 效果 。 
<script language="javascript"> 
‘ourmove(); 
</script> 


国 秘笈 心 ; 


心 法 领悟 218: 使 用 ourmove0 函 数 的 注意 事项 。 
一 定 要 将 调用 ourmove0 函 数 的 代码 放 在 </body> 标 记 之 前 ， 否 则 页 面 的 其 他 内 容 需 要 等 动画 显示 完毕 才 可 
以 显示 ， 达 不 到 预期 的 效果 。 
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力 实例 说 明 


在 设计 网 站 的 导航 菜单 时 ， 有 时 为 了 让 用 户 快速 了 解 菜 单 导航 的 详细 内 容 ， 需 要 为 菜单 设置 提示 信息 。 这 
样 当 用 户 鼠 标 移动 到 菜单 项 上 时 就 会 显示 提示 信息 ， 效 果 如 图 3.75 所 示 。 


明日 图 书 ”编程 社区 企业 简介 ”意见 反馈 | 
力 因 书 用 户 提供 在 和 和 旦 溉 务 


图 3.75 解释 型 菜单 


图 关键 技术 


本 实例 主要 应 用 超 链接 中 的 title 属性 实现 解释 型 菜单 。 在 定义 超 链接 时 为 其 设置 title 属性 ， 就 可 以 实现 菜 


单 的 提示 功能 ， 例 如 
<a href="#" title = "为 图 书 用 户 提供 在 线 答疑 服务 "> 明日 图 书 &nbsp;&nbsp; <a> 


图 设计 过 程 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 


(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 3 行 1 列 的 表格 ， 在 表格 的 第 2 行 再 添加 一 个 1 行 4 列 的 表格 。 


(3) 在 霸 套 的 表格 中 加 入 超 链接 ， 主 要 代码 如 下 : 
<td width="123" scope="col" align="right"> <a href="#" title = "为 图 书 用 户 提供 在 线 答疑 服务 "> 明日 图 书 &nbsp;&nbsp; </a></td> 
<td width="79" scope="col" ali "><a href="#" title = "为 编程 人 员 提 供 一 个 在 线 交流 平台 "> 编程 社区 &nbsp;&nbsp:</a></td> 
<td width="78" scope="col" align="right"><a href="#"> 企 业 简介 &nbsp:&nbsp:</a></td> 
<td width="82" scope="col" align="right"><a href="#"> 意 见 反馈 &nbsp;&nbsp;</a></td> 


图 秘笈 心 法 


心 法 领悟 219: 使 用 CSS 样式 统一 超 链接 效果 。 
在 设计 表单 页 面 时 ， 通 常 需要 统一 某 一 类 表单 元 素 的 效果 。 例 如 ， 统 一 超 链 接 文本 字体 的 大 小 、 文 本 颜色 
等 。 一 种 简单 的 方式 是 利用 CSS 样式 来 实现 ， 例 如 


<style> 


af 
font-size:16px: 
ee 


这 样 页 面 中 的 超 链接 字体 均 为 16 个 像素 ， 颜 色 为 哨 红 色 。 


: 


趣味 指数 : 但 广 食 全 S| 


实例 220 


力 实例 说 明 


网 站 中 的 导航 菜单 是 网 站 首页 必 不 可 少 的 表单 元 素 ， 美 观 、 新 颖 的 导航 菜单 会 为 网 站 增色 许多 。 本 实例 将 
实现 一 个 半 透 明 效果 的 菜单 ， 效 果 如 图 3.76 所 示 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


网 站 导航 技术 支持 


Tema 
ena 


| 明日 图 书 | 明日 软件 | 编程 体验 | 编程 资源 | 内 部 论坛 | 


3.76 半 透 明 效果 菜单 


图 关键 技术 


半 透 明 效 果 的 菜单 可 以 通过 CSS 样式 中 的 滤 镜 filter 来 实现 。 在 滤 镜 中 使 用 alpha 属性 设置 透明 程度 (范围 


为 0~100，0 表示 完全 透明 ，100 表示 不 透明 ) ， 其 语法 格式 如 下 : 
{Filter:alpha(opacity=opacity, finishopacity=finishopacity.sytle=sytle.startx=startx,starty=starty, finishx=finishx, 
finishx=finishyx)} 
例如 ， 下 面 的 语句 将 滤 镜 透明 度 设置 为 50%。 

Filter: Alpha(Opacity=50): 


图 设计 过 程 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 


(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 3 行 1 列 的 表格 ， 在 第 2 行 中 再 添加 一 个 1 行 3 列 的 表格 。 
(3) 定义 CSS 样式 表 ， 设 置 超 链 接 的 效果 和 半 透 明 菜 单 的 效果 ， 代 码 如 下 : 


<style type="text/css"> 

At 

COLOR: blue; FONT-SIZE: 10pt; TEXT-DECORATION: none:color:#FF6600 
} 


A:hover { 
COLOR: black; FONT-SIZE: 10pt:color:#395531 
} 
,transMenu { 
BORDER: #666666 1px solid; 
FONT: 12px Verdana; 
POSITION: absolute; 
background-image:url("images/item out.ipg"); 
background-repeat : repeat-y; 
Filter: Alpha(Opacity=50); 
} 


</style> 


(4) 利用 JavaScript 脚本 控制 菜单 的 显示 与 隐藏 ， 代 码 如 下 : 
<script language="javascript"> 
function ShowMenu(divID, menultem){ // 显 示 子 菜单 
if(document.al){ 
switch (menultem){ 
case ' 网 站 导航 ': 


{ 
var htmltxt = "<a href = 'www.mingribook.com'> 明日 图 书 网 站 </a> <br> <a href= 
"www.mrbced.cn'> 明日 编程 社区 </a> <br> <a href= "www.mrsoft.com'> 明日 软件 </a> <br>"; 


MenuID innerHTML = htmltxt: /设置 DIV 代码 
MenuID style padding = "Spx"; /设置 DIV 边 距 
MenuID style height = "SSpx"; // 设 置 DIV 高 度 
break: 

} 

case 技术 支持 ': 


var menutxt = "<a href = "www.mingribook.com’> QQ </a> <br> <a href = wwwmrbcedcn> 
MSN </a> <br> <a href = "www.mrsoft.com’> Phone </a> <br>"; 


MenuID innerHTML = menutxt: // 设 置 DIV 代码 
MenulD.style .padding = "Spx"; /设置 DIV 边 距 
MenulD .style height = "5Spx": /设置 DIV 高 度 
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break: 
} 


中 
/设置 菜单 显示 位 置 
MenulD .style.left = document.body.scrollLeft + event.clientX - eventoffsetX: 
MenulD style.top = document.body.scrollTop + event.clientY - event.offsetY + 18 ; 
MenulD.style.display = "block": 
} 
function HideMenu){ // 隐 藏 子 菜 单 
if(document.al){ 
MenulD style.display = "none"; /隐藏 DIV 
} 


(document.al){ 
document.onmousemove = HideMenu; // 鼠 标 在 表单 中 移动 时 隐藏 菜单 

} 

<lscript> 


心 法 领悟 220: 设置 鼠标 移动 到 超 链接 的 效果 。 
在 使 用 超 链 接 时 通常 会 为 超 链接 设置 一 些 特效 。 例如 ， 当 用 户 鼠 标 移动 或 单 击 超 链接 时 文本 颜色 发 生变 化 。 
要 实现 这 一 功能 最 简单 的 方式 是 定义 CSS 样式 表 ， 例 如 : 


Athover { 
FONT-SIZE: 10pt: 
color:#395531 

} 


i 四 
实例 说 明 


二 级 导航 菜单 是 许多 网 站 通常 采用 的 菜单 导航 形式 。 项 行 显示 一 级 菜单 ， 其 下 显示 二 级 菜单 。 当 用 户 选择 
不 同 的 一 级 菜单 时 ， 二 级 菜单 会 动态 发 生变 化 。 本 实例 就 实现 这 种 效果 的 导航 菜单 ， 如 图 3.77 所 示 。 


Visual C++ | Visual Basic | PHP 


图 3.77 二 级 导航 菜单 


力 关键 技术 


实现 二 级 导航 菜单 的 关键 是 二 级 菜单 的 显示 。 当 用 户 选择 不 同 的 顶层 菜单 时 需要 显示 不 同 的 二 级 菜单 。 这 
里 我 们 用 DIV 作为 二 级 导航 菜单 的 容器 ， 通 过 动态 设置 DIV 对 象 的 innerHTML 属性 来 实现 动态 显示 二 级 菜单 
的 效果 。 

看 设计 过 程 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 保 存 为 index.php 文件 。 


(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 2 行 1 列 的 表格 ， 在 第 1 行 中 再 添加 一 个 1 行 4 列 的 表格 ， 在 第 2 
行 再 添加 一 个 1 行 2 列 的 表格 。 表 单 代码 如 下 : 


<form id="form1" name="forml”" method="post" action=""> 
<table width="610" height="441" border="0" align="center"> 
<t> 
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<th height="62" align="right" valign="bottom" scope="col"><table width="337" border="1" align="right" cellpadding="0" cellspacing="0" 
bordercolor="#993399" background="images/menuBK JPG"> 
<t> 
<td width="327" scope="col"> <a href =# onmousemove= MenuCtrl( 论 坛 中 心 'subMenu):> 论 坛 中 心 <a><ltd> 


<td width="327" scope="col"><a href = 当 onmousemove=MenuCtrl(' 勘 误 发 布 'subMenu'):> 勘 误 发 布 <a></ltd> 
<td width="327" scope="col"><a href = 党 onmousemove=MenuCtrl(' 作 品 展示 ''subMenu);> 作 品 展示 </a></td> 
<td width="327" scope="col"><a href = 党 onmousemove=MenuCtrl( 联 系 我 们 ','subMenu'):> 联 系 我 们 </a></td> 
<lt> 
<ltable></th> 
<> 
<tr valign="top"> 
<td height="373"><table width="606" border="0" align="center"> 
<tr> 
<th width="283" scope="col">&nbsp:</th> 
< 由 width="313" seope="col"><div id="subMenu" align="left"></div></th> 
<l> 
</table></td> 
</> 
</table> 
</form> 
(3) 利用 JavaScript 脚本 控制 二 级 菜单 的 显示 ， 代 码 如 下 : 
<script lan 
var curSel ="": 
function MenuCtrl(menuID, divID){ 
var divObj = document.getElementById(divID); /获取 DIV 对 象 


switch (menuID){ /判断 项 层 菜单 
case "论坛 中 心 ': 


/在 DIV 中 显示 子 菜单 

divObj innerHTML = "<a href = #>Visual C++ |<a href = '#> Visual Basic |<a href = #'> PHP </a>"; 
eurSel = 论坛 中 心 '; 

brealk 


} 
case ' 勘 误 发 布 : 
{ 
/在 DIV 中 显示 子 菜单 
divObj.innerHTML = "<a href = > 光盘 错误 |<a href= 风 > 文档 错误 |<a href= %> 目 录 错 误 </a>"; 
eurScl= ' 勘 误 发 布 : 
break 


} 
case 作品 展示 ': 
: 
/在 DIV 中 显示 子 菜单 


divObj.innerHTML = "<a href = 风 > 视 频 学 VB |<a href= 风 > 视频 学 VC |<a href=#> 
视频 学 Asp net |<a hre 全 迪 > 视频 学 C# </a>"; 


eurSel = ' 作 品 展 心 ; 
break: 
} 
case ' 联 系 我 们 ': 
/在 DIV 中 显示 子 菜单 
divObj.innerHTML = "<a href = #>0ICQ [a href = > MSN|<a href = #> Phone</a>"; 
eurSel = 联系 我 们 ': 
break: 
} 
| 
让 (documentalD{ 
MenuCtrl( 论坛 中 心 'sobMenu'): // 上 默认 情况 下 显示 第 一 个 顶层 菜单 的 二 级 菜单 项 
} 
<Jscript> 
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秘笈 心 法 
心 法 领悟 221: 设置 表格 单 边框 效果 。 


默认 情况 下 ， 表 格 具有 双边 框 ， 在 利用 表格 进行 界面 布局 时 这 种 效果 会 影响 页 面 的 美观 性 ， 可 以 通过 将 表 
格 的 cellspacing 属性 设置 为 0 来 实现 表格 的 单 边 框 效果 ， 例 如 : 


<table width="337" border="1" cellspacing="0" bordercolor="#993399" background="images/menuBK.JPG"> 


Wo 


力 实例 说 明 


导航 条 是 网 站 设计 中 不 可 缺少 的 元 素 之 一 ， 它 能 正确 地 引导 浏览 者 查找 需要 的 资料 ， 成 为 浏览 者 的 网 站 路 
标 。 同 时 网 页 导航 条 的 设计 风格 也 能 影响 到 页 面 的 整体 风格 ， 对 于 一 个 静态 元 素 居多 的 页 面 ， 可 以 为 导航 条 添 
加 动态 效果 ， 这 样 可 以 使 整个 网 站 不 至 于 太 呆板 ， 增 强 网 页 的 欣赏 价值 。 例 如 ， 在 明日 实业 网 站 中 ， 笔 者 将 导 
航 条 设计 成 动画 效果 ， 用 户 将 鼠标 移动 到 任意 一 个 导航 按钮 上 时 ， 该 按钮 都 会 突出 显示 ， 鼠 标 移出 后 ， 又 恢复 
为 原来 的 位 置 ， 运 行 结 果 如 图 3.78 所 示 。 


图 3.78 ”导航 条 的 动画 效果 


力 关键 技术 


本 实例 主要 是 通过 Image 对 象 的 鼠标 事件 控制 Image 对 象 的 sre 属性 的 值 实现 的 。 

在 JavaScript 里 提供 了 对 图 像 进行 处 理 的 专用 对 象 Image 来 装 入 文档 的 图 形 。Image 对 象 与 其 他 对 象 的 差别 
在 于 ,其 允许 通过 构造 器 显示 和 创建 新 的 Image 对 象 ,创造 和 预 装 入 的 图 形 之 前 并 非 Web 页 面 的 组 成 部 分 .Image 
对 象 存在 于 浏览 器 的 缓冲 区 中 ， 用 于 蔡 换 已 经 显示 的 图 像 。 

用 Image 构造 器 创建 图 形 的 语法 格式 如 下 : 


ObjImg=new image() /创建 了 一 个 新 的 Image 对 象 ， 并 将 其 赋予 变量 ObjImg 
ObjImg.sre=" 图 片 文件 相对 路 径 " /设置 Image 对 象 的 Sre 属性 
图 设计 过 程 


(1) 准备 14 张 图 片 。7 张 鼠标 移出 时 显示 的 图 片 ， 图 片 的 名 称 为 “menu_0+1~7 的 数字 +.gif”，7 张 鼠 标 
移入 时 显示 的 图 片 ， 图 片 的 名 称 为 “menu_0+1~7 的 数字 + _over.gif”。 

(2) 将 准备 的 7 张 鼠 标 移出 时 显示 的 图 片 按 顺序 插入 页 面 中 的 适当 位 置 , 并 设置 其 鼠标 事件 onMouseMove 
和 onMouseout 执行 的 操作 ， 这 里 分 别 调用 两 个 不 同 的 自 定义 JavaScript 函数 ， 关 键 代码 如 下 : 


<img sre="Images/top/menu_01.gif' id="image1" width="95" height="119" border="0" onMouseMove="move(this'1)" onMouseout="out(this'1')"> 
<img sre="Images/top/menu_02.gif" id="image2" width="95" height="119" border="0" onMouseMove="move(this.2)" onMouseout-"outtthis.2)"> 
<img sre="Images/top/menu_03.gif" name="image3" width="95" height="119" border="0" onMouseMove="move(this,3')" 
onMouseout="out(this.'3)"> 

<img sre="Images/top/menu 04.gif' name="image4" width="94" height="119" border="0" onMouseMove="move(this.4)" onMouseout="out(this.4")"> 
<img sre="Images/top/menu_05.gif" name="image5" width="95" height="119" border="0" onMouseMove="move(this,'$)" onMouseout="out(this,5)"> 
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<img sre—"Images/top/menu_ 06.gif" name—"image6" width="94" height="119" border="0" onMouseMove—"move(this:6')" onMouseout="out(this,6)"> 
<img sre="Images/top/menu_07.gif’ width="95" name="image7" height="119" border="0" onMouseMove="move(this,7")" onMouseout="out(this,7)"> 
(3) 编写 自 定义 的 JavaScript 函数 move0 和 out0，move0 函 数 用 于 设置 鼠标 移入 导航 按钮 时 显示 的 图 片 ， 
outO 函 数 用 于 设置 鼠标 移出 导航 按钮 时 显示 的 图 片 ， 代 码 如 下 : 
<script language="javaseript> 
// 和 鼠标 移动 效果 
var A_Img=new Image0; 
function move(image.num){ 
image.sre=Tmages/top/menu 0'+num+’ over.gif; 


function out(image.num){ 
image src=Tmagesltop/menu_0+numt'gif; 
</script> 


心 法 领悟 222: Image 构造 器 。 
在 利用 Image 对 象 编程 之 前 ,利用 <img> 标 记 显 示 属 性 。 在 HTML 中 ,要 显示 图 片 可 以 用 如 下 语句 来 实现 : 


<img sre="pictureName.gif" name="ImgName"> 


在 JavaScript 中 可 以 用 下 面 的 方式 访问 Image 对 象 : 


document Img.src=" menu_01.gif' 
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第 4 章 文件 操作 


4.1 文件 上 传 


文件 上 传 是 网 站 中 一 个 非常 重要 的 功能 ， 特 别 是 在 网 站 的 后 台 管理 系统 中 ， 需 要 通过 此 功能 向 网 站 中 上 传 
很 多 数据 ， 包 括 图 片 、 文 件 等 。 


Ce 


实例 223 趣味 指数 ; 三 丰 从 


力 实例 说 明 


文件 的 上 传 可 以 分 为 两 类 : 一 类 是 上 传 文件 到 服务 器 ， 即 存储 到 服务 器 指定 的 文件 夹 下 ; 另 一 类 是 将 数据 
以 二 进 制 的 形式 上 传 到 数据 库 中 。 具 体 采用 哪 种 方式 ， 需 要 根据 程序 的 实际 需要 而 定 。 

本 实例 中 将 介绍 如 何 将 文件 以 二 进 制 的 形式 上 传 到 数据 库 中 ， 并 且 输 出 上 传 的 数据 。 运 行 结果 如 图 4.1 
所 示 。 
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图 4.1 将 文件 以 二 进 制 的 形式 上 传 到 数据 库 


力 关键 技术 
本 实例 主要 应 用 表单 中 的 文件 域 提交 图 片 文件 ， 代 码 如 下 : 


<input name="cover" type="file" id="cover" size="30"> 
其 中 ， 参 数 type 指定 表单 元 素 的 类 型 为 文件 域 ，name 指定 表单 元 素 的 名 称 ; size 指定 表单 元 素 的 大 小 。 
通过 $_POST 方法 获取 表单 中 提交 的 数据 ， 并 应 用 insert 语句 将 表单 中 的 数据 添加 到 数据 表 中 。insert 语句 
的 语法 如 下 : 


Insert into table_name (column_namel.column name2. ... ) values (valuel, value2. ... ) 
参数 说 明 : 

table name: 数据 表 的 名 称 。 

column_namel: 数据 表 中 字段 的 名 称 。 
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valuel: 表单 提交 的 变量 。 

在 index_ok.php 文件 中 ， 通 过 fopen0 函 数 和 fread() 函 数 读 取 表 单 中 提交 的 图 片 数 据 ， 并 且 将 返回 的 数据 存 
储 到 数据 库 中 。 

在 这 里 要 特别 注意 网 页 编码 格式 的 使 用 。 如 果 网 页 的 编码 格式 是 UTF-8， 那 么 在 获取 上 传 文件 的 存储 路 径 
时 ， 必 须 将 UTF-8 编码 格式 的 字符 串 转换 为 GB2312 编码 格式 ， 否 则 文件 不 能 被 fppen0 函 数 读 取 。 


图 设计 过 程 
(1) 通过 Dreamweaver 开发 工具 创建 一 个 index.php 页 , 添加 一 个 表单 ,设置 表单 的 method 属性 值 为 post， 
Action 属性 值 为 ndex_ok.php; 添加 表单 元 素 ， 提 交 图 书信 息 ， 添加 提交 按钮 ， 其 关键 代码 如 下 : 


<form name="form" method="post" action="index_ok.php" onSubmit="return check_form(this)"> 
<input name="cover" type="file" id="cover" size="30"> 
<input type="submit" name="Submit" value=" 提 交 "> 
</form> 
(2) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 连 接 MySQL 数据 库 服务 器 ， 连 接 db_database04 数据 库 ， 设 
置 数 据 库 变 量 格式 为 utf8。 
(3) 创建 index_ok.php 文件 ,通过 $_POST 方法 获取 表单 中 提交 的 数据 ， 并 判断 上 传 图 片 的 格式 是 否 正 确 ， 


通过 fopen0) 函 数 和 fread0 函 数 读 取 表单 中 提交 的 图 片 数 据 ， 编 写 insert 语句 将 数据 添加 到 指定 的 数据 表 中 ， 其 


关键 代码 如 下 : 
<?php 
include ("conn/conn.php"); // 连 接 数据 库 
Sbookname =$_POST["bookname"]; // 获 取 表单 中 提交 的 数据 


Sprice =$_POST["price"]; 
Smaker =$_POST["maker"]: 
SissuDate = date("Y-m-d H:i:s"); 
Spublisher =$_POST["publisher"]; 
$synopsis = $_POST["synopsis"]: 
if($ POSTI"Submit"] =— true) { 
Scover = $_FILES["cover"][‘name']: 1/ 获取 表单 中 提交 的 图 片 
Scover_type = strstr($cover, "."); /获取 从 “.” 到 最 后 的 字符 
if (Seover type != "jpg" && Scover type (= "gif && Scover type = 
"JPG" && $cover type !=".GIF" && $cover_type != ".bmp" && Scover type (= 
.BMP { 1/ 判断 图 片 的 格式 
echo "<script>alert(' 封 面 图 片 格式 不 对 ， 请 进行 处 理 后 在 上 传 ! ): window.location href='index.php';</script>"; 
}else{ 
Scover=iconv("utf-8","gb2312",$coven): 1/ 设置 字符 串 的 编码 格式 
Spath = "uploadfiles/".Scover: 
@move_uploaded_file($_FILES["cover"]["tmp_name"].$path): 


$fp = fopen($path, "tb"); /以 二 进 制 形式 打开 图 片 
Simage = addslashes( 

@fread($fh. filesize($path))): // 读 取 二 进 制 的 数据 

// 将 数据 添加 到 指定 的 数据 表 中 


$sql = "insert into 
tb_book(bookname,price.maker.issuDate.publisher,synopsis.cover)values('‘$bookname','$price','$maker','$issuDate','$publisher','$synopsis','$image’)"; 
Sresult = mysql query($sql, 
$conn); 
if ($result — true) { 
echo iconv("utf-8",."gb2312"," 文 件 上 传 成 功 11"); 
echo "<meta http-equiv=\"refresh\" content=\"30 url=index.php\">"; 
}else{ 
echo iconv("utf-8","gb2312"," 文 件 上 传 失败 11"); 
echo "<meta http-equiv=\"refresh\" content=\"30 url=index.php\">"; 
1 
大 
} 


> 
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心 法 领悟 223: 读 取 数据 库 中 存储 的 二 进 制图 片 数据 。 
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读 取 数 据 库 中 存储 的 二 进 制图 片 数据 需要 定义 一 个 单独 的 文件 ， 根 据 数据 的 ID 值 执行 查询 ， 并 应 用 
mysql reultO 函 数 返 回 查询 结果 ， 最 后 输出 查询 结果 。 本 实例 中 定义 的 是 images.php 文件 ， 通 过 该 文件 完成 对 数 
据 库 中 存储 的 二 进 制图 片 的 读 取 操 作 。images.php 的 代码 如 下 : 

php 


include ("conn/conn.php"); // 连 接 数据 库 
Squery = "select + from tb_book where id=" . $_GET[recid]:; // 定 义 查询 指定 数据 的 语句 
Sresult = mysql_ query($query): // 执 行 查询 
if(! $result) 

die("error: mysql query"): // 返 回 失败 的 结果 
Snum = mysql_num_rows($result); // 获 取 查 询 结果 的 数量 
($num <1) 

die("error: no this recorder"); // 如 果 查 询 结果 小 于 则 说 明 没有 数据 
S$data = mysql_result($result 0, "cover"): // 获 取 查 询 结 果 
mysql_close($conn); // 关 闭 数据 库 
echo $data; /| 输出 返回 的 数据 


?> 


高 级 | 
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力 实例 说 明 

在 开发 网 站 的 过 程 中 ， 不 但 可 以 将 文件 上 传 到 数据 库 中 ， 而 且 可 以 将 文件 上 传 到 服务 器 ， 这 种 方式 可 以 为 
网 站 中 的 数据 库 节 省 很 多 空间 ， 同 时 可 以 控制 上 传 文件 的 大 小 、 格 式 ， 并 且 读 取 服务 器 中 的 文件 要 比 从 数据 库 
中 读 取 方 便 很 多 。 运 行 本 实例 ， 如 图 4.2 所 示 ， 单 击 图 中 的 “浏览 ”按钮 ， 选 择 要 上 传 的 文件 ， 然 后 单 击 “ 提 
交 ” 按 钮 ， 如 果 上 传 成 功 ， 则 在 页 面 中 提示 “上 传 成 功 ! ”， 和 否则 给 出 错误 提示 信息 。 


一 个 此 人 nins 
CR 


达 挥 上传 文件 : end_Franevork_7H. chn 攻守 


上 传 图 片 


上 传 错误 :上 传 文件 大 小 超出 配置 文件 规定 值 
cepyright © 1999-2010 吉林 省 明日 科技 有 限 公司 


4.2 ”上传 文件 


力 关键 技术 


在 PHP 中 ,应 用 move_uploaded file0 函 数 实 现 将 文件 上 传 到 指定 文件 夹 。 但 是 ， 在 执行 文件 上 传 之 前 , 为 
了 防止 潜在 的 攻击 对 原本 不 能 通过 脚本 交互 的 文件 进行 非法 管理 , 可 以 先 应 用 is_uploaded file0 函 数 判断 指定 的 
文件 是 否 通过 HITP POST 上 传 ， 如 果 是 则 返回 TRUE。is_uploaded file0 函 数 的 语法 如 下 : 

boolis_uploaded_file ( string filename ) 

参数 filename 必须 指定 类 似 于 $_FILES['filename']['tmp_name'] 的 变量 ， 不 可 以 使 用 从 客户 端 上 传 的 文件 名 
$_ FILES[filename'][name'] 。 

通过 is_uploaded file0 函 数 对 上 传 文件 进行 判断 , 可 以 确保 恶意 的 用 户 无 法 欺骗 脚本 去 访问 本 不 能 访问 的 文 
件 ， 如 /etc/passwd。 

move_uploaded file0) 函 数 将 文件 上 传 到 服务 器 中 指定 的 位 置 。 如 果 成 功 返回 TRUE， 否 则 返回 FALSE， 其 
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语法 如 下 : 


bool move uploaded file ( string filename, string destination ) 


参数 filename 指定 上 传 文件 的 临时 文件 名 ， 即 $_FILES[tmp_name]; 参数 destination 指定 文件 上 传 后 保存 的 


新 路 径 和 名 称 。 


| 说 明 :如 果 参 数 filename 不 是 合法 的 上 传 文件 ,不 会 出 现任 何 操作 ,move_uploaded file0 函 数 将 返回 FALSE。 
如 果 参 数 filename 是 合法 的 上 传 文件 ， 但 出 于 某 些 原因 无 法 移动 ， 也 不 会 出 现任 何 操作 ， 
move_uploaded file0) 函 数 将 返回 FALSE， 并 且 还 会 发 出 一 条 警告 。 


图 设计 过 程 


(1) 创建 index.php 文件 ， 添 加 表单 ， 设 置 enctype 属性 值 为 "multipart/form-data"， 添 加 文件 域 、 提 交 按 钮 ， 


使 用 POST 方法 ， 将 表单 中 的 数据 提交 到 本 页 。 


(2) 通过 $_FILES 获取 上 传 文件 的 相关 信息 ， 通 过 move_upload_file0 函 数 完 成 图 片 的 上 传 ， 代 码 如 下 : 


<?php 
if(!empty($_FILES[up_picture][name]){ 
if($_FILES['up_picture']['error]>0){ 
echo "上 传 错误 :"; 
switeh($_FILES['up_picture][ error){ 


ase 1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break; 
Case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break: 


case 3: 
echo "上 传 文件 不 全 "; 
break: 


case 


本 
echo "没有 上 传 文件 "; 


} 
yelse{ 
(is_dir(",/upfile/)){ 
mkdir("./upfile/"); 


} 
$path=' /upfile/' time().strstr($_FILES['up_picture [name],.); 
if(is_uploaded file($_FILES['up_picture']['tmp_name']){ 
if(!Imove_uploaded_file($_FILES['up_picture']['tmp_name'],$path)) { 
echo "上 传 失败 ": 
jelse{ 


// 判 断 上 传 内 容 是否 为 空 
// 判 断 文 件 是 否 可 以 上 传 到 服务 器 


// 判 断 指定 目录 是 否 存 在 
// 创 建 目录 


// 定 义 文件 名 称 和 存储 位 置 
// 是 否 通过 HTTP POST 上 传 
/执行 上 传 


echo "文件 ".time().$_FILES['up_picture']['name']." 上 传 成 功 ， 大 小 为 :".$_FILES['up_picture']['size]: 


} 
yelse{ 
echo "上 传 文件 ".$_FILES[up_pictute][mame']." 不 合法 ! “: 
| 
} 
} 


?> 
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如 果 应 用 $_FILES['picture']['error] 对 上 传 文件 的 信息 进行 判断 ， 当 其 返回 值 为 2 时 , 说 明 上 传 文件 的 大 小 超 
出 了 表单 中 约定 的 范围 ， 而 表单 中 的 这 个 约定 值 是 通过 隐藏 域 MAX_FILE_SIZE 的 值 来 控制 的 。 在 设置 这 个 隐 


藏 域 时 ， 必 须 将 其 放置 在 文件 域 之 前 ， 否 则 不 起 作用 。 
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力 实例 说 明 


在 网 站 开发 的 过 程 中 ， 为 了 确保 充分 地 利用 服务 器 的 空间 ， 在 开发 上 传 功 能 时 最 好 能 够 对 上 传 文件 的 大 小 
进行 控制 。 本 实例 开发 的 上 传 功能 就 可 以 对 上 传 文件 的 大 小 进行 控制 。 如 果 上 传 文件 的 大 小 超过 指定 范围 ， 那 
么 将 给 出 提示 信息 ， 并 终止 上 传 。 运 行 效果 如 图 4.3 所 示 。 


一 个 战 TA 


记 反 上传 文件 : end_Franevork_7H. cx 


上 传 图 片 大 小 为 《 28 


上 传 错误 :上 传 文件 大 小 超出 配置 文件 规定 值 
Cepyright @ 1999-2010 吉林 省 明日 科技 有 限 公司 


4.3 限制 上 传 文件 的 大 小 


图 关键 技术 


控制 上 传 文件 的 大 小 有 两 个 关键 点 : 一 是 PHP 的 配置 文件 php.ini 对 上 传 文件 的 控制 , 如 果 上 传 文件 的 大 小 
超过 其 指定 的 范围 , 那么 上 传 就 会 失败 ; 二 是 在 PHP 配置 文件 允许 的 范围 内 , 在 程序 中 对 上 传 文件 大 小 的 控制 。 
(1) 在 PHP 中 ， 通 过 php.ini 文件 对 上 传 文件 进行 控制 ， 包 括 是 否 支持 上 传 、 上 传 文件 的 临时 目录 、 上 传 
文件 的 大 小 、 指 令 执行 的 时 间 、 指 令 分 配 的 内 存 空间 。 
在 php.ini 文件 中 ， 定 义 到 File Uploads 项 ， 完 成 对 上 传 相关 选项 的 设置 。 上 传 相关 选项 的 含义 如 下 : 
file_uploads: 如 果 值 是 on， 说 明 服 务 器 支持 文件 上 传 ; 如 果 为 off， 则 不 支持 。 一 般 默 认 是 支持 的 ， 
不 需 修改 。 
upload tmp_dir: 上 传 文件 的 临时 目录 。 在 文件 被 成 功 上 传 之 前 ， 首 先 存放 到 服务 器 端的 临时 目录 中 。 
多 数 使 用 系统 默认 目录 ， 但 是 也 可 以 自行 设置 。 
upload_max_filesize: 服务 器 允许 上 传 文件 的 最 大 值 ， 以 MB 为 单位 。 系 统 默认 为 2:MB， 如 果 网 站 需 
要 上 传 超过 2MB 的 数据 ， 那 么 就 要 修改 这 个 值 。 
上 述 是 php.ini 文件 的 File_ Uploads 项 中 与 上 传 相关 选项 参数 的 设置 说 明 , 除了 File Uploads 项 中 的 内 容 外 ， 
在 php.ini 文件 中 还 有 几 个 选项 会 影响 到 文件 的 上 传 。 
max_execution time: PHP 中 一 个 指令 所 能 执行 的 最 大 时 间 ， 单 位 是 秒 。 在 上 传 超大 文件 时 必须 修改 该 
选项 ， 否 则 即使 上 传 文件 在 服务 器 允许 的 范围 内 ， 若 是 超过 了 指令 所 能 执行 的 最 大 时 间 ， 仍 然 无 法 实 


现 上 传 。 
memory_limit: PHP 中 一 个 指令 所 分 配 的 内 存 空间 ， 单 位 是 MB， 其 大 小 同样 会 影响 到 超大 文件 的 
上 传 。 


(2) 在 客户 端 控 制 上 传 文件 ， 应 用 的 是 form 表单 中 的 enctype 和 method 属性 ， 以 及 隐藏 域 MAX_FILE_ 
SIZE。 
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enctype="multipart/form-data":， 指定 表单 编码 数据 方式 。 
method="post": 指定 数据 的 传输 方式 。 
<input type="hidden" name="MAX_ FILE_SIZE" value="10000" />: 通过 隐藏 域 控制 上 传 文件 的 大 小 ( 单 
位 为 字 节 ) ， 该 值 不 能 超过 php.ini 配置 文件 中 upload_max_filesize 选项 设置 的 值 。 它 不 能 完全 控制 上 
传 文件 的 大 小 ， 只 是 可 以 避免 一 些 不 必要 的 麻烦 。 

上 述 两 种 判断 的 结果 都 可 以 通过 全 局 变量 $_FILES 的 返回 值 来 体现 。$_FILES 是 一 个 数组 ， 包 含 所 有 上 传 
文件 的 信息 。 下 面 介 绍 $_FILES 数组 中 每 个 元 素 的 含义 ， 如 表 4.1 所 示 。 


表 4.1 $_FILES 数组 中 的 元 素 


因 办 办 


元 素 名 说 有明 
$ FILES[filename][name] 存储 上 传 文件 的 文件 名 ， 如 text.txt、title.jpg 等 
$ FILES[filename][size] 存储 文件 大 小 ， 单 位 为 字 节 
S$_FILES[filename][tmp name] 存储 文件 在 临时 目录 中 使 用 的 文件 名 。 因 为 文件 在 上 传 时 ， 首 先 要 将 其 以 临时 文件 的 身 
一 = 份 保 存在 临时 目录 中 
存储 上 传 文件 的 MIME 类 型 ，MIME 类 型 规定 各 种 文件 格式 的 类 型 。 每 种 MIME 类 型 都 
$_FILES[filename][type] 是 由 “/” 分 隔 的 主 类 型 和 子 类 型 组 成 ， 如 image/gif， 主 类 型 为 “图 像 ”， 子 类 型 为 GIF 


格式 的 文件 ，texvhtml 代表 文本 的 HTML 文件 

存储 与 文件 上 传 相关 的 错误 代码 。 此 项 目 是 PHP 4.2.0 版 本 中 新 增 的 内 容 ， 其 返回 值 有 
以 下 5 种 : 

0: 表示 没有 任何 错误 ， 文 件 上 传 成 功 

1: 表示 上 传 文件 的 大 小 超出 了 PHP 配置 文件 指令 upload_max_filesize 选项 限制 的 值 

2: 表示 上 传 文件 的 大 小 超出 了 HTML 表单 中 MAX_FILE_SIZE 选项 所 指定 的 值 

3: 表示 文件 只 被 上 传 了 一 部 分 

4: 表示 没有 上 传 任何 文件 


$_FILES[filename][error] 


图 设计 过 程 

(1) 创建 index.php 文件 。 

(2) 为 index.php 文件 添加 表单 ， 设 置 enctype 属性 值 为 "multipart/form-data"， 添 加 文件 域 、 提 交 按 钮 ， 使 
用 POST 方法 将 表单 中 数据 提交 到 本 页 。 

(3) 通过 $_FILES 获取 上 传 文件 的 相关 信息 ， 通 过 move_upload_file0 函 数 完成 图 片 的 上 传 ， 代 码 如 下 : 


< 


这 !empty($_FILES[up_picture][nameD)){ // 判 断 上 传 内 容 是 否 为 空 
if($_FILES['up_picture'][ error]>0){ // 判 断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错误 :"; 


switch($_FILES['up_picture']['error){ 
case 1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break; 


case 


2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break; 


Case 3: 
echo "上 传 文件 不 全 "; 
Ee 


和 
echo "没有 上 传 文件 "; 
break; 


} 
Jelse{ 
if(tis_dir("./upfile/"){ // 判 断 指 定 目录 是 否 存在 
mkdir("./upfile/"); // 创 建 目录 
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} 
Spath=./upfile/".time() .strstr($_FILES['up_picture][name],.); // 定 义 文件 名 称 和 存储 位 置 
iflis_uploaded file($_FILES[up_picture][tmp_namec])){ // 是 否 通过 HTTP POST 上 传 
if(!move_uploaded file($_FILES['up_picture'][‘tmp_name'].$path){ // 执 行 上 传 
echo "上 传 失败 ":; 
Jelse{ 


echo "文件 ".time0.$_FILES['up_picture][name']." 上 传 成 功 ， 大 小 为 :".$_FILES[wp_picture']['size']; 


Jelse{ 
echo "上 传 文件 "S_FILES[up_pictute][name] "不 合法 ! "; 
} 
} 
} 
> 


心 法 领悟 225: 如 何 上 传 超大 文件 。 
如 果 要 上 传 超 大 文件 ， 必 须 修改 php.ini 文件 。 修 改选 项 包括 : upload max filesize 的 最 大 值 、 
max_execution_time 一 个 指令 所 能 执行 的 最 大 时 间 和 memory_limit 一 个 指令 所 分 配 的 内 存 空 间 。 


起 味 指数 : 庚 友 庚 安 


图 实例 说 明 
在 开发 文件 上 传 功能 时 ， 不 仅 要 考虑 上 传 文件 的 大 小 ， 有 时 还 要 考虑 上 传 文件 的 类 型 ， 针 对 不 同 的 需要 对 
上 传 文件 的 类 型 加 以 限制 ， 这 里 指 的 文件 类 型 可 以 通过 文件 的 扩展 名 《如 .txt、.php、.doc) 来 判断 。 例 如 ， 在 
进行 文件 上 传 时 ， 涉 及 文本 说 明 性 文字 时 ， 最 好 将 上 传 的 文件 限制 为 以 “.txt” 为 后 绥 的 文本 格式 。 
运行 本 实例 ,如 图 4.4 所 示 ， 单 击 图 中 的 “浏览 ”按钮 选择 要 上 传 的 文件 (文件 不 是 以 “.txt” 为 扩展 名 》， 
单 击 “ 提 交 ” 按 钮 ， 程 序 将 给 出 错误 提示 。 


加 一 个 上 人 wins 


过 皇上 传 文件 : 「 vamppwampp_star 攻 有 HK 


上 傅 文 件 天 型 为 (tm) 


EED CE 


上 传 文件 类 型 不 正确 ? 


DA 
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图 4.4 限制 上 传 文件 的 类 型 


图 关键 技术 


文件 的 上 传 和 对 大 小 的 限制 已 经 在 前 面 的 实例 中 讲解 过 ， 这 里 只 讲解 限制 上 传 文件 类 型 的 关键 技术 ， 首 先 
要 通过 预定 义 全 局 变量 $_ FILES 中 的 $_FILES[files][name] 获 取 上 传 文件 的 名 称 ， 然 后 应 用 strstr0 函 数 截取 上 传 
文件 名 称 的 后 组， 最 后 判断 上 传 文件 的 后 缀 是 否 符合 要 求 。 


strstr0 函 数 的 语法 如 下 : 
string strstr(string strings, string needle); 
该 函数 用 于 在 字符 串 strings 中 查找 字符 串 needle 的 位 置 , 并 返回 从 needle 字符 串 开始 到 strings 字符 串 结束 
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的 所 有 内 容 ， 如 果 在 strings 中 没有 查找 到 needle， 该 函数 将 返回 FALSE。 


力 设计 过 程 
(1) 继续 使 用 实例 225 的 内 容 ， 在 其 基础 上 增加 对 上 传 文件 类 型 的 判断 ， 增 加 的 关键 代码 如 下 : 
<?php 
这 !empty($_FILES[up_picture][namec])){ // 潮 断 上 传 内 容 是 否 为 空 
S$type=$_FILES[up_picture[name']: /获取 上 传 文件 的 名 称 
$types=strstr($type 1/ 截取 上 传 文件 的 后 级 
if($types—".txt"){ // 判 断 上 传 文件 的 后 级 是 否 符合 要 求 
/省 略 了 部 分 代码 
} 
Yelse{ 
echo "上 传 文件 ".$_FILES['up_pictute"][name"]." 类 型 不 正确 ! "; 
} 
} 
?> 
(2) 重新 保存 index.php 文件 。 
图 秘笈 心 法 


心 法 领悟 226: 判断 上 传 的 文件 是 否 符合 多 种 类 型 中 的 一 种 。 

判断 上 传 的 文件 是 否 符合 多 种 类 型 中 的 一 种 ， 最 佳 的 方法 就 是 将 多 种 类 型 定义 到 一 个 数组 中 ， 然 后 通过 for 
循环 输出 数组 中 的 元 素 值 ， 将 输出 的 元 素 值 与 获取 的 文件 后 缀 进行 比较 ， 进 而 判断 其 是 否 符合 要 求 。 

EO , 

高 级 : 

趣味 指数 : 依依 食 依 家 


实例 227 | 


力 实例 说 明 


上 传 图 片 到 服务 器 ， 是 程序 开发 过 程 中 必 不 可 少 的 一 个 功能 。 它 不 但 可 以 达到 共享 图 片 的 目的 ， 而 且 可 
以 提高 网 站 的 访问 量 ， 丰 富 网 站 的 内 容 。 在 本 实例 中 将 讲解 如 何 通过 POST 方式 实现 多 图 片上 传 ， 运 行 结果 如 
图 4.5 所 示 。 


~ 一 个 此 起 wT 人 二 


多 文件 上 伟 ( 一 次 最 多 上 传 :个 图 片 》 


名 称 


流 晶 电视 
页 次 : 616 页 记录 : 54 条 分 页 : 首页 123436 尾 页 
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图 4.5 POST 方式 实现 多 图 片上 传 
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图 关键 技术 


多 文件 上 传 的 关键 是 如 何 定义 上 传 文件 元 素 的 名 称 及 判断 上 传 文件 的 数量 。 在 本 实例 中 ， 以 数组 的 形式 定 
义 上 传 文件 的 名 称 〈 上 传 文件 的 名 称 是 “files[]”) 。 为 了 达到 可 以 上 传 任意 数量 图 片 〈4 个 图 片 以 内 ) 的 目的 ， 
在 对 上 传 文件 进行 处 理 的 过 程 中 应 用 armray_filter0 函 数 和 回调 函数 去 除数 组 中 的 空 元 素 。 

array_filter() 函 数 ， 用 回调 函数 过 滤 数 组 中 的 单元 ， 语 法 如 下 : 

array array_filter ( array input [. callback callback] ) 

array_filter0 函 数 依次 将 input 数组 中 的 每 个 值 传递 到 callback0 函 数 。 如 果 callback0 函 数 返 回 TRUE， 则 
input 数组 的 当前 值 会 被 包含 在 返回 的 结果 数组 中 ， 并 且 数 组 的 键 名 保留 不 变 。 


上 上 说 明 : 在 回调 函数 中 不 要 对 数组 进行 修改 操作 ， 例 如 ， 增 加 或 者 删除 数组 中 的 元 素 ， 如 果 一 旦 数组 改变 ， 
那么 此 函数 的 运用 也 就 没有 意义 了 。 如 果 没 有 提供 callback0) 函 数 ，array_filter0) 函 数 将 删除 input 中 
所 有 等 值 为 FALSE 的 元 素 。 


本 实例 中 定义 的 回调 函数 是 check0)， 用 于 验证 数组 中 的 元 素 值 是 否 为 空 ， 其 语法 如 下 : 
function check($var) { /验证 数组 的 返回 值 是 否 为 空 
retum ($var {= ""); 


[al 说 明 : 通过 POST 方法 实现 多 图 片上 传 ， 在 创建 form 表单 时 ， 必 须 指定 enctype="multipart/form-data" 属 性 。 
如 果 要 通过 隐藏 域 MAX_FILE_SIZE 的 值 对 上 传 文件 的 大 小 进行 控制 ， 那 么 必须 将 隐藏 域 放置 在 上 
传 文件 的 文件 域 之 前 ， 否 则 是 不 会 起 作用 的 。 


力 设计 过 程 


(1) 创建 index.php 文件 。 添 加 表单 ， 设 置 文件 域 、 提 交 按 钮 ， 使 用 POST 方法 设置 enctype="multipart/ 
form-data"， 将 数据 提交 到 index_ok.php 页 ， 完 成 多 个 文件 的 上 传 操作 ， 其 关键 代码 如 下 : 


<table width="750" border="0" cellspacing="0" cellpadding="0"> 
<form action="index_ok.html" method="post" enctype="multipart/form-data" name="form1"> 
<tr> 
<td width="100" height="25" align="right" class="STYLE1"> 内 容 1: </td> 
<td width="150" align="center"><input name="files[]" type="text" id-"filles[]" size="15"></td> 
<td align="left"><input name="picture[]" type="file" id="picture[]" size="30"></td> 
<tr> 
<tr> 
<td height="25" align="right" class="STYLE1"> 内 容 2: </td> 
<td align="center"><input name="files[]" type="text" id="files[]" size="15"></td> 
<td align="left"><input name="picture[]" type="file" id="picture[]" size="30"></td> 
</tr> 
<tr> 
<td colspan="3" align="center"> 
<input type="image" name="imageFicld" src="images/bg_09jpg">&nbsp:&nbsp:&nbsp:&nbsp: 
<input type="image" name="imageField2" sre—"images/bg 11.jpg"></td> 


(2) 在 index.php 文件 中 ， 连 接 数 据 库 ， 读 取 数据 库 中 存储 的 数据 ， 实 现 上 传 文件 的 分 页 输出 。 代 码 请 参 
考 光盘 中 的 相关 内 容 。 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 将 多 个 文件 存储 到 服务 器 中 ， 将 文件 的 名 称 和 存储 
路 径 存储 到 数据 库 中 ， 其 代码 如 下 : 
2 ( "Content-type: text/html; charset=UTF-8" ): // 设 置 文件 编码 格式 
include "conn/conn.php": // 包 含 数据 库 链接 文件 
if($_POST [files] = "") { 
if(lis dir ("./upfile" )) { 
mkdir ("Jupfile" ): // 创 建 上 传 文件 存储 文件 夹 
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} 


$data = date ( "Y-m-d H:m:s" ); /定义 时 间 

function check(Svan) { /验证 数组 的 返回 值 是 否 为 空 
retum ($var {= ""); // 如 果 不 为 空 ， 则 返回 数组 元 素 

} 

$files = array_filter ( $_POST ["files"], "check" ); /去 除数 组 中 的 空 值 

Sarray = array_filter ($_FILES ["picture"] ["name"], "check" ); /去 除数 组 中 的 空 值 

foreach ( $array as Skey => $value ) { 1/ 循环 读 取 数组 中 的 数据 
Spath = upfile/ . time 0 . $key . strtolower ( strstr ( $value, "." ) ); /定义 上 传 文件 存储 位 置 


move_uploaded_file ($_FILES ["picture"] ["tmp_name"] [Skey]. $path ): /执行 上 传 操作 
Squery = "insert into tb_up_file (file_test.data,file_name) values (‘$path','$data','$files[Skey])"; 
Sresult = mysql_query ( $query ); 
echo "<script>alert(' 图 片上 传 成 功 ); window.location href='index.html';</script>"; 


} 
> 


国 秘笈 心 法 
心 法 领悟 227: 通过 伪 静 态 技术 隐藏 PHP 文件 后 缀 。 
首先 ， 修 改 Apache 服务 器 的 配置 文件 httpd.conf。 打 开 httpd.conf 文件 ， 定 位 到 如 下 位 置 : 


| 
将 该 项 前 面 的 “#” 去 掉 后 启动 该 项 。 
然后 , 查找 httpd.conf 文件 , 找到 其 中 的 AllowOverride 项 , 将 它 的 值 都 修改 为 All。 保存 并 重新 启动 Apache 
kt 使 修改 生效 。 
A htaccess 文件 ， 实 现 对 PHP 文件 后 缀 的 隐藏 操作 。.htaccess 文件 的 代码 如 下 : 


报 后 在 On # 启 动 

RewriteRule index.html$ 

RewriteRule ‘index_ok.html$ index_ok.php 

RewriteRule ^index-([0-9]+)-([0-9}+)-([0-9}+)\html$ indexphp?vv=Sl&liil-S2&page=S3 [L] 


通过 正则 表达 式 对 文件 的 后 缀 和 传递 的 参数 进行 匹配 ， 完 成 对 PHP 文件 后 缀 的 隐藏 操作 。 


4.2 文件 下 载 


全 | 


力 实例 说 明 


在 一 个 完整 的 网 站 中 ， 具 有 文件 下 载 功能 能 够 给 网 站 带 来 更 多 的 访问 者 ， 增 加 网 站 的 访问 量 。 最 常用 的 文 
件 下 载 方式 就 是 通过 链接 下 载 。 在 本 实例 中 ， 应 用 链接 方式 进行 下 载 ， 当 单 击 “ 下 载 ” 超 链接 时 ， 即 可 弹出 文 
件 “ 另 存 为 ”对 话 框 ， 完 成 下 载 保存 操作 ， 运 行 结果 如 图 4.6 所 示 。 


4.6 链接 方式 的 文件 下 载 
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图 关键 技术 


本 实例 主要 通过 超 链接 来 实现 文件 的 下 载 。 通 过 select 语句 从 数据 库 中 读 取 文件 存储 的 路 径 ， 然 后 将 该 文 
件 作 一 个 超 链 接 ， 当 单 击 “ 下 载 ” 超 链接 时 ， 即 可 下 载 该 文件 。 


力 设计 过 程 
(1) 在 实例 227 的 基础 上 ， 为 输出 的 图 片 名 称 创建 超 链接 ， 完 成 图 片 的 下 载 操作 ， 其 关键 代码 如 下 : 


<a href="<?php echo Smyrow[file_test]:?>"><?php echo $myrow[file name]:?></a> 
(2) 保存 对 文件 的 修改 ， 运 行程 序 ， 运 行 结果 参看 实例 说 明 。 


心 法 领悟 228: 不 同类 型 的 文件 ， 下 载 操作 不 同 。 
如 果 是 压缩 的 文件 ， 可 以 直接 下 载 ， 如 果 不 是 ， 则 需要 右 击 ， 然 后 在 弹出 的 快捷 菜单 中 选择 “另存 为 ”命令 。 


Ce 
A 进行 下 载 中 级 | 
起 味 指数 : 裕 契 亦 容 


力 实例 说 明 


除了 可 以 通过 链接 方式 下 载 文件 之 外 ， 还 可 以 通过 header0 函 数 完成 下 载 操 作 。 例 如 ， 本 实例 中 就 是 应 用 
header0 函 数 实现 文件 的 下 载 ， 如 果 下 载 的 文件 不 存在 ， 则 会 给 出 提示 信息 ， 运 行 结果 如 图 4.7 所 示 。 


您 起 打开 或 保存 此 文件 吗 ? 


名 称 : 12759792140.png 
类 型 PNG 图 像 , 1.95 KB 
发 送 者 : 127.0.0.1 


打开 @) | _ 保存 &) | [区 汪汪 
© 各 


图 4.7 应 用 header0 函 数 实现 文件 下 载 


力 关键 技术 


通过 HTTP 方式 下 载 文件 ， 主 要 应 用 header() 函 数 。 

headerO 函 数 属 于 HITP 函数 , 其 作用 是 以 HITP 协议 将 HTML 文档 的 标 头 送 到 浏览 器 , 并 告诉 浏览 器 具体 
怎么 处 理 这 个 页 面 。header0 函 数 的 语法 如 下 : 

void header ( string string [, bool replace [. int http_response_code]] ) 

参数 说 明 : 

string: 发 送 的 标 头 。 

replace: 如 果 一 次 发 送 多 个 标 头 ， 对 于 相似 的 标 头 是 蔡 换 还 是 添加 。 如 果 是 FALSE， 则 强制 发 送 多 个 同类 
型 的 标 头 。 默 认 是 TRUE， 即 蔡 换 。 

http_response_code: 强制 HITP 响应 为 指定 值 。 
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通过 HTTP 下 载 的 代码 如 下 : 


header("Content-type: application/x-gzip"): 
header("Content-Disposition: attachment': filename= 文 件 名 "): 

header("Content-Description: PHP3 Generated Data"); > 

HTTP 标 头 有 很 多 ， 这 里 介绍 的 是 下 载 的 HTTP 标 头 ， 其 代码 如 下 : 
header('Content-Disposition: attachment: filename="filename"); 


在 应 用 过 程 中 ， 唯 一 需要 改动 的 就 是 flename， 即 将 filename 蔡 换 为 要 下 载 的 文件 。 
设计 过 程 
(1) 在 实例 227 的 基础 上 ， 为 输出 的 图 片 创建 超 链接 ， 链 接 到 download.php 文件 ， 通 过 download.php 完 
成 文件 的 下 载 操作 。 在 index.php 文件 中 所 做 的 修改 如 下 : 


<td width="245" height="100" align="center" valign="middle" bgcolor="#FOFOF0"><a href="download-<?php echo $myrow[file_test]:?>.html" title=" 
点 击 即 可 下 载 ! "><?php echo "<img sre=\"$myrow[file_test]\" width=\"250\" height=\"100\W border=\"0W>"?></a></td> 


(2) 创建 download.php 文件 ， 应 用 header0 函 数 实现 文件 的 下 载 ， 其 代码 如 下 : 


<2php 
header("Content-type: text/html: charset=UTF-8"); // 设 置 文件 编码 格式 
Spath = $_GET['path"]; /获取 文件 路 径 
if(!empty($path) and !is_null($path)){ 1/ 判断 变量 是 否 为 空 ， 是 否 为 NULL 
$filename=basename($path); /获取 文件 名 
$file=@fopen($path,"r"); 
if($file){ 
header("Content-type:application/octet-stream"); /输出 MIME 类 型 
header("Accept-ranges:bytes"); // 接 受 的 范围 单位 
header("Accept-length:".filesize($path)); /文件 长 度 
header("Content-Disposition:attachment;filename=".$filename); 。 ”// 默 认 的 文件 保存 对 话 框 中 的 文件 名 称 
echo fread($file, filesize($path)); // 读 取 文 件 
felose($file); /| 关闭 文件 
exit; /退出 
jslse{ 
echo "<script>alert(' 您 下 载 的 文件 不 存在 ! '); history.backO:;</script>": 
} 
} 
> 


国 秘笈 心 法 
心 法 领悟 229: headerO 函 数 的 应 用 。 
通过 headerO 函 数 不 但 可 以 实现 文件 的 下 载 ， 还 可 以 实现 以 下 3 个 功能 : 
(1) 重 定向 ， 这 是 最 常用 的 功能 。 


header("Location: http://www.mrbeed.com"): 


(2) 强制 客户 端 每 次 访问 页 面 时 获取 最 新 资料 ， 而 不 是 使 用 存在 于 客户 端的 缓存 。 
/设置 页 面 的 过 期 时 间 (用 格林 威 治 时 间 表示 ) 
header("Expires: Mon. 08 Jul 2008 08:08:08 GMT"): 
// 设 置 页 面 的 最 后 更 新 日 期 (用 格林 威 治 时 间 表示 ) ， 使 浏览 器 获取 最 新 资料 
header("Last-Modified: " . gmdate("D., dM Y Hii:s") . "GMT"): 


header("Cache-Control: no-cache, .must-revalidate"): /控制 页 面 不 使 用 缓存 

header("Pragma: no-cache"): /参数 〈 与 以 前 的 服务 器 兼容 ) ， 即 兼容 HTTP 1.0 协议 
header("Content-type: application/file"): /输出 MIME 类 型 

header("Content-Length: 。 227685"): /文件 长 度 

header("Accept-Ranges: 。 bytes"): /接受 的 范围 单位 

// 上 默认 的 文件 保存 对 话 框 中 的 文件 名 称 

header("Content 一 Disposition: attachment: filename=$filename"): // 实 现下 载 


(3) 输出 状态 值 到 浏览 器 ， 控 制 访问 权限 。 
header(HTTP/1.1 401 Unauthorized"): 
header('status: 401 Unauthorized’); 
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实例 230 


力 实例 说 明 


在 开发 网 站 的 过 程 中 ， 很 多 的 服务 条 款 、 协 议 等 都 是 以 文本 文件 的 形式 存储 的 。 如 果 要 读 取 这 些 文件 中 的 


内 容 ， 就 需要 应 用 到 文件 系统 函数 。 在 本 实例 中 将 介绍 如 何 通过 文件 系统 函数 读 取 整 个 文件 的 内 容 ， 其 运行 效 
果 如 图 4.8 所 示 。 
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4.8 读 取 文本 文件 的 内 容 
力 关键 技术 


在 PHP 中 ， 读 取 整 个 文件 的 内 容 ， 有 3 个 函数 可 以 选择 : 
readfile() 函 数 


readfile() 函 数 读 取 一 个 文件 并 将 其 写 入 输出 缓冲 ， 如 成 功 ， 返 回 读 取 的 字 节 数 ， 如 失败 ， 返 回 FALSE， 
语法 如 下 : 

intreadfile ( string filename [, bool use_include_path [, resource context] ) 

参数 flename 指定 读 取 的 文件 名 称 ， 参 数 use_include_path 控制 是 否 支 持 在 include_path 中 搜索 文件 ， 如 果 
支持 ， 则 将 该 值 设置 为 TRUE; 参数 context 是 PHP 5.0 的 新 增 内 容 。 
[ED 说 明 : 应 用 readfile0 函 数 时 ， 不 需要 打开 /关闭 文件 和 输出 语句 ， 直 接应 用 即 可 。 

fneO 函 数 


file0 函 数 将 整个 文件 的 内 容 读 入 一 个 数组 中 。 如 成 功 ， 返 回 数组 ， 数 组 中 的 每 个 元 素 都 是 文件 中 对 应 的 一 
行 ， 包 括 换行 符 在 内 ， 如 失败 ， 返 回 FALSE。 语 法 如 下 : 


array file ( string filename [, int use_include path [, resource context]] ) 
其 参数 与 readfile0 函 数 相 同 ， 唯 一 区 别 是 该 函数 的 返回 值 是 数组 。 
回 file_get_contents0 函 数 


人 le_get_contents0 函 数 将 文件 内 容 读 入 一 个 字符 串 。 如 果 有 offset 和 maxlen 参数 ,将 在 参数 offset 所 指定 的 


二 | 
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位 置 开始 读 取 长 度 为 maxlen 的 内 容 。 如 果 失 败 ， 返 回 FALSE。 语 法 如 下 : 
string file_get_contents ( string filename [. bool use_include_path [. resource context [, int offset [, int maxlen]]]] ) 
参数 filename 指定 读 取 的 文件 名 称 ; 参数 use_include_path 控制 是 否 支持 在 include_path 中 搜索 文件 ， 如 果 
支持 ， 则 将 该 值 设 置 为 TRUE。 


图 设计 过 程 
(1) 创建 index.php 文件 。 


(2) 在 index.php 文件 中 分 别 应 用 fle0 和 file_get contents0 函 数 读 取 文 本 文件 中 的 内 容 ， 其 关键 代码 如 下 : 
<!-- 使 用 他 e0 函 数 读 取 count.txt 文件 的 内 容 -> 


<?php 
Sarr = 人 ile(testltxty; 
foreach ($arr as $value) { 
echo iconv("gb2312", "utf-8", $value) . "<br>"; 
} 
?> 
<!-- 使 用 fle_get_contents0 函 数 读 取 count.txt 文件 的 内 容 --> 


?php 
S$str = file_get_contents('test2.txt); 
echo iconv("gb2312", "utf-8", $str); 
?> 


图 秘笈 心 ; 

心 法 领悟 230: 读 取 整 个 文件 的 特性 。 

在 通过 readfile0、file0 和 file_get_contents0 函 数 读 取 整个 文件 中 的 内 容 时 ， 不 需要 通过 fopen() 函 数 打 开 文 
件 ， 也 不 需要 使 用 felose0 函 数 关闭 文件 。 

但 是 ,在 读 取 一 个 字符 、 一 行 字符 和 任意 长 度 的 字符 串 时 ， 必 须 应 用 fopen0 函 数 打开 文件 后 才能 进行 读 取 ， 
在 读 取 完 成 后 还 要 应 用 fcloseO 函 数 关闭 文件 。 


ge 
图 实例 说 明 


在 遍历 文件 中 的 内 容 时 ， 由 于 文件 内 容 很 多 ， 最 理想 的 方法 就 是 分 页 读 取 文 本 文件 中 的 内 容 。 本 实例 将 介 
绍 如 何 分 页 读 取 文本 文件 中 的 数据 ， 其 运行 结果 如 图 4.9 所 示 。 


| 诗句 评价 


“死生 到 岗 。 


4.9 文本 文件 的 分 页 读 取 
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图 关键 技术 


完成 超 长 文本 的 分 页 输出 需要 3 方面 的 技术 : 第 一 个 方面 ， 自 定义 函数 。 通 过 自 定义 函数 读 取 文本 文件 ， 
可 以 避免 中 文字 符 串 出 现 乱码 ; 第 二 个 方面 , 字符 串 函 数 。 需要 通过 strlen0 函 数 计算 字符 串 的 长 度 , 通过 substr0 
函数 对 字符 串 进行 截取 ;第 三 个 方面 ， 文 件 系统 函数 。 通 过 file_get_contents0) 函 数 读 取 文本 文件 中 的 数据 。 


自 定义 函数 msubstr0 的 语法 如 下 : 
// 定 义 一 个 用 于 截取 一 段 字符 串 的 函数 msubstr0 
function msubstr($str,Sstart.Slen){ /Sstr 指 的 是 字符 串 ，S$start 指 的 是 字符 串 的 起 始 位 置 ，$len 指 的 是 长 度 
S$strlen=$start+ $len; // 用 $strlen 存储 字符 串 的 总 长 度 〔 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i=0;$i<$strlen;$i++){ // 通 过 for 循环 语句 ， 循 环 读 取 字 符 串 
iford(substr($str,$i,1))>0xa0){ // 如 果 字 符 串 中 首 个 字 节 的 ASCI 序数 值 大 于 0xa0， 则 表示 为 汉字 
Stmpstr.=substr($str, $1.2); /| 每 次 取出 两 位 字符 赋 给 变量 Stmpstr， 即 等 于 一 个 汉字 
Bis /变量 自 加 1 
jelse{ // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 $tmpstr 
Stmpstr.=substr($str,$i,1); 
¥ 
} 
retum $tmpstr; /| 输出 字符 串 


了 
图 设计 过 程 
(1) 创建 function.php 文件 ， 编 写 自 定义 函数 msubstr0， 完 成 对 文本 文件 的 截取 操作 。 


(2) 创建 index.php 文件 ， 首 先 通过 文件 系统 函数 fle_get_ contents0 读 取 整 个 文件 的 内 容 ， 然 后 调用 自 定 
义 函数 和 字符 串 函数 完成 对 文件 的 截取 操作 ， 实 现 截取 后 内 容 的 分 页 输出 ， 其 关键 代码 如 下 : 


<div id="synopsis'> 
<!-- 创 建 div 标签 ， 用 于 获取 js 文件 中 返回 的 分 页 结果 --> 
<table width="545" border="0" cellspacing="0" cellpadding="0"> 
<t> 


<td><?php 
include("function.php"): 
// 读 取 超 长 文本 中 的 数据 ， 实 现 超 长 文本 中 数据 的 分 页 显示 
if($_GET['page ){ 
S$counter=file_get_contents("data.txt"); 
Slength=strlen($counter); 
S$page count=ceil($length/850); 
$c=msubstr($counter,0.($_GET['page']-1)*850); 
$cl=msubstr($counter,0,$_GET['page']*850); 
echo substr($cl,strlen($cj,strlen(Scl)-sttlen(Sc)); 
} 


> 
<htd> 
</t> 
<tr> 
<td><table width="535" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<!-- 设 置 超 长 文本 分 页 显示 的 超 链 接 --> 
<td width="37%" align="center" valign="middle" bgcolor="#FFFFFF"> 内 容 &nbsp:<?php echo $page_count:?> 页 
&nbsp:&nbsp: 当 前 &nbsp: 第 <?php echo $S_GET[page]:?> 页 </td> 
<td width="63%" height="28" align="center" valign="middle" bgcolor="#FFFFFF"><?php 
if($_GET[page]!=D{ 


<!-- 调 用 no_refurbish_pagination0 函 数 ， 实 现 无 刷新 的 分 页 输出 --> 
<a href="#" onClick='return no_refurbish_pagination("index_ok.php?page=1")> 首 页 </a>&nbsp: <a href="#" 
onClick='return no_refurbish_pagination("index_ok php?page=<?php echo $_GET[page']-1:?>")> 上 一 页 </a> 
php } 
这 $_GET[page]<$page_count){ 


<a href="#" onClick="return no_refurbish pagination(index_ok.php?page=<?php echo $_GET[page]+1:?>)"> 下 一 
页 </a> <a href="#" onClick='retumn no_refurbish_pagination("index_ok.php?page=<?php echo $page_count:?>")> 尾 页 </a> 
Iphp 


?> 


Ye 
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} 
> 
<itd> 
</tr> 
</table></td> 
</> 
</table> 


</div> 
(3) 创建 index_ok.php 文件 ， 实 现 数 据 的 无 刷新 分 页 。index_ok.php 中 的 内 容 与 index.php 中 <div> 标 签 
synopsis 的 内 容 相同 。 
(4) 创建 js 脚本 文件 discuss_jsjs， 通 过 AJAX 实现 无 刷新 的 操作 。 


图 秘笈 心 法 
心 法 领悟 231: AJAX 无 刷新 分 页 。 


在 本 实例 中 不 但 实现 了 文本 文件 内 容 的 分 页 输出 ， 而 且 是 无 刷新 分 页 输出 。 具 体操 作 通过 JS 脚本 文件 
discuss_js.js 和 index_ok.php 完成 。 


44 文件 操作 
wei 


力 实例 说 明 


为 了 便于 对 网 站 进行 管理 、 维 护 和 更 新 ， 应 该 设计 一 个 能 够 对 文件 进行 操作 的 模块 ， 实 现 对 文件 的 创建 、 
复制 、 移 动 和 删除 等 操作 ， 这 样 能 够 给 网 站 的 管理 工作 提供 很 大 方便 ， 不 再 因为 要 修改 某 个 文件 而 登录 到 FTP 
中 、 通 过 下 载 或 上 传 实现 文件 的 更 新 ， 从 而 节省 很 多 时 间 。 运 行 本 实例 ， 实 现 对 指定 文件 的 创建 、 复 制 、 移 动 
和 删除 操作 。 只 要 在 文本 框 中 输入 要 复制 文件 的 路 径 和 名 称 ， 在 对 应 的 文本 框 中 输入 指定 文件 要 复制 到 的 具体 
文件 夹 的 路 径 和 名 称 〈 包 括 指定 文件 的 名 称 ) ， 然 后 单 击 “提交 ”按钮 即 可 ， 运 行 结果 如 图 4.10 所 示 。 
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图 4.10 文件 操作 汇总 


图 关键 技术 
本 实例 主要 应 用 fopen0、copy0、rename0 和 unlink0 这 4 个 函数 完成 文件 的 创建 、 复 制 、 移 动 和 删除 操作 。 
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fopen0 函 数 用 于 打开 文件 或 者 URL， 其 语法 如 下 : 
ER 
创建 文件 主要 应 用 fopen0 函 数 的 mode 参数 ，mode 参数 的 可 选 值 如 下 : 
回 'w' 写 入 方式 打开 ， 将 文件 指针 指向 文件 头 并 将 文件 大 小 截 为 0。 如果 文 件 不 存在 ， 则 进行 创建 。 
回 "w+' 读 写 方式 打开 ， 将 文件 指针 指向 文件 头 并 将 文件 大 小 截 为 0。 如 果 文 件 不 存在 ， 则 进行 创建 。 
回 'a' 写 入 方式 打开 ， 将 文件 指针 指向 文件 末尾 。 如 果 文 件 不 存在 ， 则 进行 创建 。 
回 ”'at' 读 写 方式 打开 ， 将 文件 指针 指向 文件 末尾 。 如 果 文 件 不 存在 ， 则 进行 创建 。 


上 说 明 : 上 述 4 种 方式 都 可 以 完成 文件 的 创建 操作 ， 前 提 是 指定 路 径 下 不 存在 被 创建 的 文件 。 
copy0 函 数 主要 用 于 复制 文件 ， 其 语法 如 下 : 


ER 

本 函数 将 文件 从 source 复制 到 dest， 如 果 成 功 则 返回 TRUE， 和 否则 返回 FALSE。 
rename() 函 数 主要 用 于 文件 重 命 名 ， 其 语法 如 下 : 

er 

本 函数 将 oldname 重 命名 为 newname， 如 果 成 功 则 返回 TRUE， 否 则 返回 FALSE。 


[9 说 明 : ename() 函 数 不 但 可 以 给 文件 重 命名 ， 当 将 指定 的 文件 移动 到 另外 一 个 路 径 下 的 文件 天 中 时 ， 不 改变 
该 文件 的 名 称 ， 即 可 实现 对 指定 文件 的 移动 操作 。 


unlink() 函 数 主要 用 于 删除 文件 ， 其 语法 如 下 : 


bool unlink(string filename); 

该 函数 用 于 删除 文件 ， 如 果 删 除 成 功 则 返回 TRUE， 否 则 返回 FALSE。 
力 设计 过 程 

(1) 创建 index.php 文件 。 首 先 ， 设 计 文件 汇总 的 页 面 。 然 后 应 用 switch 语句 设计 一 个 简单 的 框架 ， 完 成 
复制 、 移 动 、 创 建 和 删除 操作 之 间 的 切换 。 最 后 ， 编 写 PHP 脚本 ， 根 据 表单 中 提交 的 数据 ， 执 行 不 同 的 文件 操 
作 ， 其 关键 代码 如 下 : 


<?php 
switch ($_GET [operate] { 
case "found" : 


include ("found php"); 
break: 


本 
include ("copy.php"); 
break: 

Case "move" : 

include ("move.php"); 

break:; 

case "delete" : 

include ("delete.php"); 
break:; 


default : 
include ("copy.php"); 
} 


> 


<?php 
让 ($_POST [Submit] 一 "复制 ") { 
Scopy = iconv ( "utf-8", "gb2312", $_POST [copys] ): 
Scopys2 = iconv ( "utf-8", "gb2312", $_POST ['copys2] ): 
if(copy ($copy, $copys2 )) { 
echo "<script>alert( 复 制 成 功 !1);</script>"; 
} else { 
echo "<script>alert( 复 制 失败 !1):</script>"; 
} 
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/省 略 了 部 分 代码 
?> 


(2) 分 别 创建 copyphp、deletephp、foundphp 和 movephp 文件 ， 完 成 不 同 操作 的 执行 页 面 。copy.php 文 
件 的 代码 如 下 : 
<table width="466" height="112" border="0" cellpadding="0" cellspacing="0"> 
<form name="form1" method="post" action=""> 
<t> 
<td width="111" rowspan="2" align="center"> 复 制 文件 <td> 
<td width="67" align="right" valign="bottom">copy: </td> 
<td width="229" height="39" valign="bottom"><input name="copys”" 
type="text" id="copys" size="22"></td> 
<td width="126" rowspan="2" align="left" valign="middle"><input 
type="submit" name="Submit" value=" 复 制 "></td> 
</lt> 
<t> 
<td align="right" valign="top">affix: </td> 
<td height="41" valign="top"><input name="copys2" type="text" 
id="copys2" size="22"></td> 


<td colspan="4" align="center"> 例 如 : F:\xampp\htdocs\MR\05\012\test.txt</td> 


图 秘笈 心 ; 


心 法 领悟 232: 编码 格式 转换 的 必要 性 。 

在 应 用 文件 操作 函数 执行 文件 的 创建 、 移 动 、 复 制 和 删除 操作 时 ， 由 于 实例 的 页 面 编码 格式 是 UTF-8， 所 
以 从 表单 中 获取 的 元 素 值 不 能 直接 应 用 到 文件 操作 函数 中 ， 必 须 对 其 进行 编码 转换 ， 由 UTF-8 编码 转换 为 
GB2312 编码 ， 否 则 文件 操作 函数 不 能 正确 地 执行 。 


力 实例 说 明 


对 目录 、 文 件 的 操作 不 应 该 是 盲目 的 ， 应 该 首先 确定 其 是 否 存 在 ， 如 果 存 在 才能 对 它 执行 各 种 操作 ， 否 则 
是 没有 任何 意义 的 。 相 反 ， 有 些 操作 必须 是 在 指定 的 目录 、 文 件 不 存在 的 情况 下 进行 的 。 此 时 必须 有 一 个 方法 
能 够 对 目录 、 文 件 进行 定位 ， 确 定 它 是 否 存在 ， 这 就 是 本 实例 将 要 讲解 的 内 容 。 运 行 本 实例 ， 在 文本 框 中 输入 
目录 、 文 件 的 完整 路 径 ， 单 击 “提交 ”按钮 ， 运 行 结 果 如 图 4.11 所 示 。 


文件 名 称 : [FE WPpSewwwWMRO4O14 提交 


请 辆 入 正确 的 目录 、 文件 路 径 b 


和 1 CepyBiahts © reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.11 目录 、 文 件 定位 器 
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[上 说 明 : 本 实例 实现 的 功能 虽然 非常 简单 ， 但 是 这 个 方法 在 很 多 程序 中 都 会 被 用 到 ， 只 是 表现 的 方式 不 同 。 


图 关键 技术 


PHP 中 判断 指定 的 目录 、 文 件 是 否 存在 ， 应 用 的 是 file_exists0 函 数 ， 该 函数 的 语法 如 下 : 
int file_exists(string filename); 
该 函数 用 来 检测 目录 、 文 件 是 否 存 在 ， 如 果 存 在 返回 TRUE， 否 则 返回 FALSE。 
(aa 说 明 : 要 在 Windows 下 检查 网 络 中 的 共享 文件 应 该 使 用 //computername/share/filename 或 者 \computername\ 
share\filename。 


图 设计 过 程 
(1) 创建 index.php 文件 ， 设 计 页 面 布局 。 
(2) 添加 表单 ， 设 置 文 本 框 ， 提 交 目 录 、 文 件 的 完整 路 径 ， 并 设置 提交 按钮 。 
(3) 编写 PHP 脚本 ， 获 取 表 单 中 提交 的 目录 、 文 件 路 径 。 首 先 对 获取 的 元 素 值 进行 编码 格式 的 转换 ， 然 
后 应 用 fe_exists() 函 数 判 断 指定 的 目录 、 文 件 是 否 存 在 ， 其 关键 代码 如 下 : 
党 POST [file name] ="") { 
Sfile name =iconv ( "utf-8", "gb2312", $ POST ['file name']); 
if (file_exists ( $file_name )) { 
echo "<script>alert(' 目 录 、 文 件 已 定位 ! :</script>"; 
else 
: 于 文件 不 存在 ! :</script>"; 
J 人 "<script>alert(' 请 输入 正确 的 目录 、 文 件 路 径 ! ;</script>"; 
} 


> 
图 秘笈 心 ; 
心 法 领悟 233，UTF-8 编码 格式 对 中 文字 符 串 的 影响 。 
在 本 实例 中 , 由 于 使 用 的 是 UTF-8 编码 格式 , 因此 当 提 交 的 目录 、 文 件 路 径 中 存在 中 文字 符 串 时 , file_exists() 


函数 就 不 能 正确 地 判断 目录 、 文 件 是 否 存在 。 只 有 将 UTF-8 编码 格式 的 元 素 值 转换 为 GB2312 编码 格式 之 后 ， 
file_exists0 函 数 才能 对 中 文字 符 串 的 目录 、 文 件 路 径 作 出 正确 的 判断 。 


: Ce i 
力 实例 说 明 


在 对 网 站 进行 管理 和 维护 的 过 程 中 ， 经 常会 修改 文件 的 名 称 。 本 实例 将 介绍 一 种 修改 文件 名 称 的 方法 。 运 
行 本 实例 ， 在 “原文 件 名称 ” 文 本 框 中 输入 原始 文件 的 存储 路 径 和 文件 名 ， 在 “新 文件 名 称 ”文本 框 中 输入 新 
文件 的 路 径 和 文件 名 ， 单 击 “ 提 交 ” 按 钮 ， 运 行 结果 如 图 4.12 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


原文 伯 各 各 : [FApOSeWWWWNROIAOISWVAGESSE 


提交 
得 症 6 称 : FSeVwwwAMROADINIMAGESVestT | 
C2 


An copy 和 ts © reserred 20:0 青 村 省 明科 技 有 限 公司 


图 4.12 修改 文件 名 


力 关键 技术 

文件 重 命名 应 用 的 是 rename0 函 数 ， 不 过 首先 要 应 用 file_exists0 函 数 判断 该 文件 是 否 存在 ， 如 果 存在 则 应 
用 rename0 函 数 对 该 文件 进行 重 命名 ， 和 否则 给 出 提示 信息 。 
图 设计 过 程 

(1) 创建 index.php 文件 ， 设 计 页 面 布局 。 

(2) 添加 表单 ， 设 置 两 个 文本 框 ， 提 交 文 件 的 原始 名 称 和 新 名 称 ， 并 设置 提交 按钮 。 

(3) 编写 PHP 脚本 ， 获 取 表 单 中 提交 的 元 素 值 。 由 于 网 页 使 用 的 是 UTF-8 编码 ， 所 以 为 了 避免 在 获取 中 


文字 符 串 时 出 现 乱码 ， 应 先 用 iconv0 函 数 对 获取 的 元 素 值 进行 编码 格式 的 转换 ， 然 后 应 用 fe_exists0 函 数 判断 
指定 的 文件 是 否 存 在 ， 如 果 存 在 则 应 用 rename0 函 数 对 其 进行 重新 命名 ， 其 关键 代码 如 下 : 


<?php 
这 ($_POST['Submit] 一 "提交 ") { 
Sold_name=iconv("utf-8","gb2312",$_POST['old_name’]); // 获 取 表单 元 素 ， 并 进行 编码 格式 转换 
Snew_name=iconv("utf-8"."gb2312",$_POST['new_name']); // 获 取 表单 元 素 ， 并 进行 编码 格式 转换 
if (file_exists ( $old_name)) { 1/ 判断 文件 是 否 存在 
if(rename ( $old_name, Snew_name )) { /把 原文 件 重新 命名 
echo "修改 成 功 "; 
3 
}else{ 
print$_POST['old_name'] . "文件 不 存在 !<br>"; 
?> 
图 秘笈 心 法 


心 法 领悟 234: iconv0 函 数 在 转 码 过 程 中 的 重要 性 。 

如 果 程 序 设计 时 应 用 的 是 UTF-8 编码 ， 那 么 就 有 必要 了 解 iconv0 函 数 。 因 为 操作 系统 默认 使 用 的 是 简体 中 
文 《GB2312 编码 或 者 GBK 编码 ) ， 所 以 在 将 UTF-8 编码 格式 的 数据 应 用 到 默认 为 GB2312 编码 的 程序 中 时 ， 
难免 会 执行 失败 ,特别 是 涉及 中 文字 符 串 时 。 例 如 , 在 本 实例 中 , 如 果 直 接 将 获取 的 表单 元 素 值 应 用 到 file_existsO 
函数 或 者 rename0 〇 函数 中 ， 就 会 出 现 乱 码 。 


实例 235 浊 趣味 指数 : 廊 塘 去 家 


力 实例 说 明 


如 果 说 判断 目录 、 文 件 是 否 存在 是 对 目录 、 文 件 进行 操作 的 前 提 条 件 ， 那 么 获取 文件 属性 则 是 对 文件 进行 
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操作 的 必要 条 件 。 因 为 在 执行 一 些 特殊 的 操作 之 前 ， 必 须 对 文件 的 类 型 、 大 小 或 者 修改 时 间 进行 判断 。 在 本 实 
例 中 ， 将 介绍 如 何 获 取 文 件 的 类 型 、 大 小 和 修改 时 间 。 运 行 本 实例 ， 在 文本 框 中 输入 正确 的 目录 或 者 文件 的 路 
径 ， 单 击 “ 提 交 ” 按 钮 ， 运 行 结果 如 图 4.13 所 示 。 


文件 名 称 : |F:VAppSerWwwwiMRWD4WD15\index.php 提交 


请 给 入 正确 的 目录 、 文 件 路 征 ? 


文件 类 型 : fle 
文件 大 小 : 2403 字 节 
修改 时 间 ; 2010.07.030524.56 
An FopyRieht< © reserwea pnin 古林 省 明月 科技 有 限 公司 


图 4.13 文件 属性 分 析 


力 关键 技术 


在 PHP 中 ， 获 取 文 件 类 型 使 用 filetype0 函 数 ， 获 取 文件 大 小 使 用 filesize0 函 数 ， 而 获取 修改 时 间 使 用 
filemtime() 函 数 。 
filetype() 函 数 用 于 获取 文件 类 型 ， 其 语法 如 下 : 


string filetype ( string filename ) 
该 函数 返回 文件 的 类 型 ， 类 型 值 包括 fifo、char、dir、block、link、file 和 unknown。 如 果 出 错 则 返回 FALSE。 
filesize() 函 数 用 于 获取 文件 大 小 ， 其 语法 如 下 : 


int filesize ( string filename ) 


该 函数 返回 文件 大 小 的 字 节 数 ， 如 果 出 错 返回 FALSE 《在 错误 报告 级 别 为 E WARNING 的 情况 下 ) 。 


| 说 明 : 因为 PHP 的 整数 类 型 是 有 符号 的 ， 并 且 大 多 数 平台 使 用 32 位 整数 ，filesize() 函数 在 碰 到 大 于 2GB 
的 文件 时 可 能 会 返回 非 预 期 的 结果 。 对 于 2GB~4GB 之 间 的 文件 通常 可 以 使 用 sprintf("%u"， 
filesize($file)) 来 克服 此 问题 。 
filemtime0 函 数 用 于 获取 文件 修改 时 间 ， 其 语法 如 下 : 


ER 
该 函数 返回 文件 上 次 被 修改 的 时 间 ， 出 错时 返回 FALSE。 时 间 以 UNIX 时间 戳 的 方式 返回 ， 可 用 于 date0 函 数 。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 计 页 面 布局 。 
(2) 添加 表单 ， 设 置 目录 、 文 件 提交 的 文本 框 ， 提 交 目 录 或 者 文件 的 路 径 ， 并 设置 提交 按钮 。 
(3) 编写 PHP 脚本 , 获取 表单 中 提交 的 元 素 值 。 首先 , 判断 提交 的 值 是 否 为 空 , 如 果 不 为 空 , 则 应 用 iconvO 


函数 对 字符 串 的 编码 格式 进行 转换 。 然 后 ， 应 用 file_exists0 函 数 判 断 指 定 的 目录 或 者 文件 是 否 存 在 ， 如 果 存 在 
则 获取 目录 或 者 文件 的 类 型 、 大 小 以 及 修改 时 间 ， 其 关键 代码 如 下 : 
< 


php 
让 ($_ POST [file name’] (="") { // 判 断 表单 提交 的 值 是否 为 空 
S$file name = iconv ( "utf-8", "gb2312". $_POST ['file name'] ): // 完 成 编码 格式 的 转换 
if (file_exists ( $file name )) { 1/ 判断 目录 或 者 文件 是 否 存在 
Sfile_type = filetype ( $file_ name ): /获取 文件 类 型 
echo "<br> 文 件 类 型 : " . $file_type . "<br>": 
if(S$file type (= "dir") { // 判 断 如 果 不 是 目录 
Sfile_size = filesize ( $file_name ): /获取 文件 的 大 小 


echo "文件 大 小 :" . $file_size . " 字 节 " . "<br>"; 
} 
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S$file_mtime = filemtime ( $file name ); /获取 目录 或 者 文件 的 修改 时 间 
echo "修改 时 间 : ". date ( "Y-m-d H:i:s", $file_mtime ); /对 返回 的 时 间 惟 进行 格式 化 输出 
}else{ 
echo "<script>alert(' 目 录 、 文 件 不 存在 ! ');</script>"; 
} 
}else{ 
echo "<script>alert(' 请 输入 正确 的 目录 、 文 件 路 径 ! ");</script>"; 
} 


?> 


心 法 领悟 235: 获取 文件 的 其 他 信息 。 

在 PHP 内 置 的 文件 系统 操作 函数 中 ， 不 仅 可 以 获取 文件 的 类 型 、 大 小 和 修改 时 间 ， 还 可 以 获取 文件 的 上 次 
访问 时 间 〈fileatime0 ) 、inode 修改 时 间 〈filectime0) 、 文 件 的 组 (filegroup0) 、 文 件 的 所 有 者 〈fileownerO ) 
和 文件 的 权限 〈fileperms0) 等 。 


图 实例 说 明 


在 开发 程序 的 过 程 中 ， 很 多 时 候 都 需要 获取 文件 的 后 缀 名 ， 并 根据 后 缀 名 作出 一 些 判断 。 那 么 如 何 才能 获 
取 文 件 的 后 级 名 呢 ?” 在 本 实例 中 将 对 这 个 问题 进行 解答 。 运 行 本 实例 ， 将 检测 表单 中 提交 文件 的 后 级 名 ， 并 根 
据 后 级 名 作出 相应 的 判断 ， 其 运行 结果 如 图 4.14 所 示 。 


‘ Er 个 贤人 的 个 人 博客 


选择 上 传 文件 : |C:\Documents and Settinc 浏览， 


文件 类 型 : chm 上 传 成 功 ， 大 小 为 : 153557 


Copii © 1999-2010 吉林 省 明日 科技 有 限 公司 
图 4.14 上 传 文件 类 型 检测 


图 关键 技术 


在 本 实例 中 应 用 move_uploaded_file0 函 数 实现 文件 上 传 的 操作 ， 并 根据 文件 的 后 级 名 进行 判断 ， 将 不 同类 
型 的 文件 存储 在 不 同 的 服务 器 文件 夹 下 。 

获取 上 传 文件 后 组 名 时 ， 首 先 应 用 $_FILES 全 局 变量 获取 上 传 文件 的 名 称 ， 然 后 应 用 strstr0 函 数 对 上 传 
文件 的 名 称 进行 截取 ， 截 取 字 符 串 中 “.” 后 的 所 有 字符 串 ， 最 后 应 用 strtolowerO 函 数 将 字符 串 转换 成 小 写 。 


strstr0) 函 数 用 于 获取 一 个 指定 字符 串 在 另 一 个 字符 串 中 首次 出 现 的 位 置 到 后 者 末尾 的 子 字符 串 ， 语 法 如 下 : 
string strstr ( string haystack, string needle) 
参数 说 明 : 


306 
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haystack: 必要 参数 ， 指 定 从 哪个 字符 串 中 进行 搜索 。 


needle: 必要 参数 ， 指 定 搜索 的 对 象 。 如 果 该 参数 是 一 个 数值 ， 那 么 将 搜索 与 这 个 数值 的 ASCII 值 相 匹配 
的 字符 。 如 果 执 行 成 功 , 则 返回 剩余 字符 串 ( 存 在 相 匹配 的 字符 ); 如 果 没 有 找到 相 匹配 的 字符 , 则 返回 FALSE。 


上 ED 说 明 : 有 关 文 件 上 传 技术 的 讲解 请 参考 实例 227， 这 里 不 再 黄 述 。 


图 设计 过 程 


(1) 创建 index.php 文件 。 


(2) 添加 表单 ， 设 置 文件 域 、 提 交 按 钮 ， 使 用 POST 方法 设置 enctype="multipart/form-data"， 将 数据 提交 


到 本 页 。 


(3) 通过 $_FILES 获取 上 传 文件 的 相关 信息 。 


(4) 应 用 is_dir0 函 数 判断 指定 的 服务 器 文件 夹 是 否 存在 ， 如 不 存在 则 应 用 mkdir0 函 数 创建 文件 夹 。 
(5) 应 用 is_uploaded_file0 函 数 判 断 文件 是 否 通 过 HTPP POST 上 传 。 
(6) 获取 上 传 文件 名 称 的 后 缀 名 ， 根 据 后 缀 名 的 不 同 ， 定 义 不 同 的 存储 路 径 。 


(7) 应 用 move_uploaded_file() 函 数 执行 文件 上 传 的 操作 。 


index.php 文件 的 关键 代码 如 下 : 
Iphp 
if(! empty ($_FILES [up_picture] [name] )) { 
if($_FILES Pop pieme] Lemer]> ©) { 

echo "上 传 错 

switch ($ 二 站 [up, )_picture] ['error]) { 


case 1 
ee "上 传 文件 大 小 超出 配置 文件 规定 信 ; 


case2 


ei "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break; 


case 3: 
echo "上 传 文件 不 全 "; 
break; 


case 4: 


echo "没有 上 传 文件 "; 
break: 


} 

} 

} else{ 

(lis dir ("txt" ) { 
mkdir ("./txt/" ); 


} 
if(lis_ dir ("piel") { 
mkdir ("./pic/" );: 


时 

if (lis dir ("/fla" ) { 
mkdir ( "la/" ): 

} 


} 

if(is_uploaded file ($_FILES [up_picture] [tmp_name’] ) { 
$type =$_FILES [up_picture] [name']; 

$types = strtolower ( strstr ( $type " ) ); 

i "txt" || Styles — ".doc") { 


"jpg" || $tyles — ".gif" || $tyles — "bmp") { 


Spath = "flan . time 0 . strstr ( $_FILES [up_picture] [name], "): 


txt/ ,time 0 . strstr ( $_FILES [up_picture] [name’]. ' ): 


pic/ .time () . strstr ( $_FILES [up_picture] [name].…): 


/判断 上 传 内 容 是 否 为 空 
// 判 断 文 件 是 否 可 以 上 传 到 服务 器 


// 判 断 指定 目录 是 否 存 在 
// 创 建 目录 


// 判 断 指 定 目录 是 否 存 在 
// 创 建 目录 


// 判 断 指 定 目 录 是 否 存在 
// 创 建 目录 


// 判 断 文 件 是 否 通 过 HTPP POST 上 传 
// 获 取 上 传 文件 的 名 称 

// 获 取 上 传 文件 的 后 缀 

// 定 义 上 传 文件 名 称 和 存储 位 置 

// 定 义 上 传 文件 名 称 和 存储 位 置 


// 定 义 上 传 文件 名 称 和 存储 位 置 
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if(! move uploaded file ($_FILES [up _picture] [tmp_name] Spath )) { /执行 上 传 操作 
echo "上 传 失败 ! "; 
}else{ 
echo "文件 类 型 : " . $types . ”上 传 成 功 ， 大 小 为 : " .$_FILES [up_picture] ['size]: 
l 
} else 
echo 
} 
?> 


心 法 领悟 236: 文件 类 型 检测 的 妙用 。 
文件 后 级 名 的 获取 可 以 应 用 到 很 多 地 方 ， 最 常用 的 就 是 通过 它 来 控制 上 传 文件 的 类 型 ， 另 外 在 文件 的 读 取 
中 ， 用 于 判断 哪些 文件 可 以 读 取 ， 哪 些 不 可 以 读 取 。 


力 实例 说 明 


{ 
"上 传 文件 :" .$_FILES [up_pictute] [name'] . "不 合法 ! "; 


文件 权限 的 判断 是 一 个 非常 重要 的 功能 ， 如 果 文 件 没有 读 、 写 的 权限 ， 那 么 就 不 能 对 其 进行 任何 操作 。 本 
实例 将 介绍 如 何 判断 文件 的 权限 。 运 行 本 实例 ， 通 过 文本 框 提交 文件 路 径 ， 向 指定 的 文件 中 写 入 数据 ， 如 果 文 
件 具 备 写 的 权限 ， 则 可 以 实现 数据 的 写 入 ， 否 则 将 提示 文件 不 具备 写 入 的 权限 ， 运 行 结果 如 图 4.15 所 示 。 

ee 梧 


RH 


文件 名 称 : [FVAppSerAwwwAMRWD4WD18\est txt 提交 


请 输入 正确 的 文件 ( 例如 : FAAppServiwwwiMRI04018Mest txt ) 9 


穹 导 不 惊 , 看 庭 前 花 开花 落 a 
文件 内 容 : | 去 留 无 意 , 望 天 上 云 卷 云 千 . 
I 


如 1 CopyRights © reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.15 判断 文件 的 权限 


力 关键 技术 


判断 文件 是 否 具备 读 权限 应 用 的 是 is_readable0 函 数 , 判断 文件 是 否 具备 写 权 限 应 用 的 是 is_writable0 函 数 。 
is_readable() 函 数 判 断 指定 文件 是 否 可 读 ， 语 法 如 下 : 


bool is_readable ( string filename ) 
如 果 文 件 存 在 并 且 可 读 ， 则 返回 TRUE。 
is_writable0 函 数 判断 指定 文件 是 否 可 写 ， 语 法 如 下 : 


bool is_writable ( string filename ) 


如 果 文 件 存在 并 且 可 写 ， 则 返回 TRUE。 参 数 filename 可 以 是 一 个 允许 进行 是 否 可 写 检查 的 目录 名 。 
< 注意 : PHP 也 许 只 能 以 运行 webserver 的 用 户 名 (通常 为 "mobody') 来 访问 文件 。 不 计 入 安全 模式 的 限制 。 
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对 于 文件 权限 的 判断 ， 是 对 文件 进行 操作 的 前 提 ， 特 别 是 在 执行 文件 的 读 取 、 写 入 、 重 命名 等 操作 时 ， 如 
果 文 件 不 具备 读 、 写 的 权限 ， 那 么 这 些 操作 是 没有 任何 意义 的 。 
图 设计 过 程 

(1) 创建 ndexphp 文件 。 

(2) 添加 表单 ， 设 置 文本 框 ， 提 交 指 定 文件 ， 设 置 文件 域 ， 提 交 写 入 文件 中 的 数据 ， 设 置 提交 按钮 ， 使 用 
POST 方法 将 数据 提交 到 本 页 。 

(3) 通过 $_ POST 方法 获取 表单 提交 的 文件 路 径 和 文件 内 容 ， 并 通过 iconv0 函 数 对 获取 的 数据 进行 编码 转 
换 。 首 先 判 断 指定 的 文件 是 否 存在 ， 然 后 判断 指定 的 文件 是 否 具备 写 的 权限 ， 如 果 有 具备 ， 则 将 表单 提交 的 文件 
内 容 写 入 文件 中 ， 最 后 关闭 打开 的 文件 ， 给 出 提示 信息 。index.php 文件 的 关键 代码 如 下 : 


php 
让 ($_POST ['file name] !="" && is_file (iconv ( "utf-8", "gb2312", $ POST ['file name’])) = true) { // 判 断 文 件 是 否 存在 
Sfile name = iconv ( "utf-8", "gb2312", $_POST ['file_ name’] ); // 编 码 转换 
Sfile_content = iconv ( "utf-8", "gb2312", $_POST [file_ content] ); 
if (file_exists ( $file name )) { 
if(is_writable ( $file name )) { // 判 断 文件 是 否 具备 写 的 权限 
$fp = fopen ( $file_name, "w+" ); /打开 指定 的 文件 
if (fwrite ( $ 印 , $file_content )) { 1/ 执行 写 入 的 操作 
echo "<script>alert( 文 件 写 入 成 功 !);</script>"; 
}else{ 
echo "<script>alert( 文 件 写 入 失败 1);:</script>"; 
} 
fclose ( $fp ): /关闭 文件 
} elseif (is_readable ( $file_name )) { 1/ 判断 文件 是 否 具备 读 的 权限 
echo "<script>alert(' 文 件 只 具备 读 权限 !);</script>":; 
}else{ 
echo "<script>alert(' 文 件 不 具备 读 、 写 权限 !);</seript>"; 
} 
}else{ 
echo "<script>alert( 文 件 不 存在 ! ");</script>"; 
}else{ 
echo "<script>alert(' 请 输入 正确 的 文件 路 径 ! "):</script>"; 
?> 
国 秘笈 心 法 


心 法 领悟 237: 通过 fileperms0O 函 数 取得 文件 的 权限 。 
本 实例 中 介绍 的 是 通过 is_readable0 和 is_writableO 函 数 来 判断 文件 是 否 具有 读 、 写 的 权限 。 在 文件 系统 的 
函数 中 还 可 以 通过 fileperms0 函 数 取 得 文件 的 权限 ， 其 返回 值 是 一 个 int 型 的 字符 串 。 


册 服务 条 款 高 级 
趣味 指数 : 太太 页 二 去 


实例 238 


力 实例 说 明 


在 网 站 开发 的 过 程 中 ， 经 常会 创建 注册 服务 条 款 或 者 会 员 须 知之 类 的 文件 。 处 理 此 类 文件 最 直接 的 方法 是 
将 其 生成 一 个 独立 的 页 面 ， 而 最 实用 的 方法 是 将 其 存储 于 独立 的 文本 文件 中 ， 从 文本 文件 中 读 取 这 些 服务 条 款 ， 
这 样 不 占用 数据 库 的 空间 而 且 不 占用 过 多 的 页 面 。 运 行 本 实例 ， 实 现 一 个 用 户 注册 的 功能 并 从 文本 文件 中 读 取 
服务 条 款 ， 运 行 结果 如 图 4.16 所 示 。 
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| Ee | 


登录 名 : 


Email 


注册 协议 


pankaihual103G sina com 

联系 电话 : 迎 您 注册 为 明日 编程 词典 服务 网 用 户 : | 
雪人 扩 和 记 和 服务 站 站 弛 过程 和 ， 

Es 

ee ，、 .+ 章 守 中 国有 关 的 法 律 和 法 规 。 不 得 利用 本 | 


全) 1599-2009 寺 林 省 明日 科技 有 限 公司 


图 4.16 从 文本 文件 中 读 取 注册 服务 条 款 


图 关键 技术 


从 文本 文件 中 读 取 注册 服务 条 款 可 以 分 为 两 个 部 分 : 第 一 部 分 是 表单 中 文件 域 的 创建 ， 第 二 部 分 是 应 用 文 
件 系 统 函 数 读 取 、 输 出 指定 文本 文件 中 的 数据 。 

这 里 应 用 文件 系统 中 的 file0 函 数 读 取 文 本 文件 中 的 数据 ， 有 关 文 本 文件 中 数据 的 读 取 可 以 参考 4.3 节 中 的 
内 容 ， 这 里 不 再 袭 述 。 


图 设计 过 程 

(1) 创建 index.php 文件 。 

首先 设计 用 户 注册 页 面 ， 然 后 添加 用 户 注册 的 表单 及 表单 元 素 ， 将 表单 元 素 的 值 提交 到 index_ok.php 页 。 
接着 编辑 JavaScript 脚本 ， 通 过 chkreginfo() 方 法 对 表单 元 素 的 值 进 行 判 断 。 


最 后 在 文本 域 中 编写 PHP 脚本 ， 通 过 fie() 函 数 读 取 指定 文本 文件 中 的 数据 ， 通 过 foreach 语句 循环 输出 注 
册 服 务 条 款 ， 其 关键 代码 如 下 : 


<textarea name="register" cols="40" rows="5" id="register"> 
?php 
Sarr = file ( ‘files/register.txt ): 
foreach ( $arr as $value ) { 
echo iconv ( "gb2312", "utf-8", $value ); 
四 } 


</textarea> 
(2) 创建 index_ok.php 文件 ， 通 过 $_POST 方法 获取 表单 中 提交 的 数据 ， 输 出 用 户 的 注册 信息 。 
(3) 在 根 目录 下 创建 js 脚本 文件 夹 ， 编 写 checkjs 脚本 文件 ， 完 成 对 表单 元 素 值 的 判断 。 


图 秘笈 心 法 
心 法 领悟 238: 读 取 文本 文件 中 的 数据 时 函数 的 选择 。 
在 文件 系统 函数 中 ， 有 多 个 可 以 读 取 文 本 文件 中 的 数据 的 函数 ， 为 了 使 读 取 到 的 数据 输出 时 条 理 更 加 清晰 ， 


建议 使 用 file0 函 数 ， 因 为 该 函数 将 读 取 到 的 数据 写 入 一 个 数组 中 ， 该 数组 中 的 每 个 元 素 是 文件 中 对 应 的 一 行 ， 
这 样 在 通过 foreach 语句 输出 数组 中 元 素 时 ， 是 按照 原文 件 中 的 行进 行 输出 的 ， 确 保 了 内 容 输出 的 条 理性 。 
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力 实例 说 明 


网 站 的 计数 器 对 于 网 站 管理 者 来 说 是 一 个 非常 值得 关注 的 部 分 ， 它 记录 了 网 站 被 访问 的 次 数 ， 客 观 地 反映 
了 网 站 受 欢迎 的 程度 。 而 文本 计数 器 是 最 简单 的 一 种 ， 它 将 数据 存储 于 文本 文件 中 。 在 本 实例 中 ， 将 介绍 这 种 
文本 计数 器 的 实现 方法 ， 并 且 将 重点 阐述 如 何 屏蔽 网 页 刷新 对 计数 器 的 影响 。 运 行 本 实例 ， 将 输出 如 图 4.17 所 
示 的 内 容 。 

最 新 动 雷 。 。 ”此 时 是 : 2015 年 1 月 20 日 16-28-54 您 是 本 网 站 第 1800012 位 访客 
图 4.17 可 以 屏蔽 刷新 功能 的 文本 计数 器 

此 时 ， 无 论 如 何 刷新 当前 页 面 ， 计 数 器 统计 的 值 都 不 会 再 发 生变 化 ， 除 非 关闭 此 页 面 重新 打开 。 

图 关键 技术 


文本 计数 器 的 设计 思路 如 下 : 首先 判断 文本 文件 是 否 存 在 ， 如 不 存在 则 打开 失败 ， 如 打开 成 功 则 继续 执行 
并 读 取 文件 中 的 数据 ， 将 计数 器 增加 1。 然 后 以 写 的 方式 重新 打开 文件 ， 把 新 的 统计 数据 写 入 文件 后 ， 关 闭 文 
件 。 最 后 重新 打开 文件 ， 读 取 并 输出 文件 中 的 数据 。 

操作 流程 如 图 4.18 所 示 。 


2 判断 文件 读 取 文 
是 否 存在 「 打开 文 | 本 文件 |[、 
回 存 | 本 文件 基 | 计数 器 加 1 
以 写 入 的 
方式 打开 
文本 文件 
重新 读 取 文件 关闭 文件 | 将 新 数据 写 入 
中 数据 ， 并 输出 文本 文件 中 


图 4.18 文本 计数 器 的 操作 流程 
按照 这 个 原理 设计 的 计数 器 ， 当 刷新 页 面 时 计数 器 的 值 也 会 增加 ， 那 么 这 个 计数 器 就 没有 任何 意义 了 。 所 
以 要 想 这 个 计数 器 有 意义 ， 必 须 屏蔽 页 面 刷新 对 计数 器 的 影响 。 
这 里 通过 SESSION 变量 来 实现 这 个 功能 ， 其 原理 如 图 4.19 所 示 。 


直接 输出 网 站 访问 量 | 中 如 不 为 空 
名 判断 SESSION 信 
11 到 | 登录 ，| 创建 登 | 变量 是 否 为 空 
网 站 录 标 记 
4 由 
用 户 ,i 
数 器 加 1 
SESSION 变量 
重新 输出 赋值 为 1 | 将 新 数据 加 入 


网 站 访问 量 文本 文件 中 


图 4.19 网 站 计数 器 的 设计 原理 
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四 设计 过 程 


(1) 创建 index.php 文件 。 首 先 设 计 网 页 页 面 ， 然 后 初始 化 SESSION 变量 ， 接 着 编写 PHP 脚本 ， 通 过 文 
件 系统 函数 完成 网 站 访问 量 的 统计 , 通过 SESSION 屏蔽 网 页 刷新 对 计数 器 的 影响 , 最 后 输出 网 站 的 访问 量 和 当 
前 时 间 ， 其 关键 代码 如 下 : 


php 
session start (); // 初 始 化 一 个 SESSION 变量 
> 
<2php 
/使 用 文本 存储 数据 
if($_SESSION [temp] —"") { 1/ 判断 $_SESSION[temp]="" 的 值 是 否 为 空 ， 其 中 的 temp 为 自 定义 的 变量 
证 (($ 印 = fopen ( "counter.txt", "r" )) — false) { 
echo "打开 文件 失败 1"; 
}else{ 
$counter = feets ( $tp, 1024 ); // 读 取 文 件 中 的 数据 
felose ( $f ); 1/ 关闭 文本 文件 
$counter ++; /计数 器 增加 1 
$ 印 = fopen ( "counter.txt", "w" ); /以 写 的 方式 打开 文本 文件 
fputs ( $ 印 , $counter ); // 将 新 的 统计 数据 增加 1 
felose ( $fp ); // 美 闭 文件 
} 
$_SESSION [temp] = 1: /| 计数 器 的 值 增加 后 ， 为 $_SESSION[temp] 赋 值 1 
} 
/从 文本 文件 中 读 取 统计 数据 
if(($fp = fopen ( "counter.txt", "r" )) 一 false) { 
echo "打开 文件 失败 1"; 
yelse{ 
$counter = fgets ( $ 印 , 1024 ); // 读 取 文 本 文件 的 数据 
felose ( $fp ): 


> 


(2) 在 实例 根 目录 下 创建 counter.txt 文本 文件 ， 用 于 存储 网 站 的 访问 量 。 
国 秘笈 心 法 


心 法 领悟 239: SESSION 防止 重复 计数 的 原理 解析 。 

首先 在 网 页 被 访问 时 初始 化 一 个 SESSION 变量 并 赋 给 其 一 个 空 值 , 然后 判断 SESSION 变量 的 值 是 否 为 空 ， 
如 果 为 空 ， 则 将 计数 器 的 值 增加 1， 并 且 为 SESSION 变量 赋值 为 1。 此 时 ， 在 当前 页 中 ，SESSION 变量 的 值 已 
经 不 为 空 ， 无 论 如 何 刷新 ，SESSION 变量 的 值 都 不 会 改变 ， 所 以 计数 器 的 值 也 不 会 增加 。 


实例 240 


力 实例 说 明 


在 网 站 的 管理 系统 中 ， 有 时 需要 查看 某 个 文件 是 否 被 修改 过 、 在 什么 时 间 被 修改 的 、 最 后 的 修改 时 间 是 
什么 ， 本 实例 就 可 以 实现 这 个 功能 ， 对 表单 中 提交 的 文件 进行 判断 ， 检 测 出 修改 时 间 ， 其 运行 结果 如 图 4.20 
所 示 。 
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图 4.20 检测 文件 是 否 被 修改 


力 关键 技术 


本 实例 主要 应 用 filectime0 和 filemtime0 函 数 ,检测 文件 的 incode 最 后 改变 时 间 和 最 后 修改 时 间 , 并 应 用 date0 
函数 对 检测 返回 的 时 间 戳 进行 格式 化 。 
ha filename 的 inode 最 后 改变 时 间 ， 语 法 如 下 : 


int filectime(string filename) 

如 成 功 则 返回 i 时 间 戳 ， 否 则 返回 FALSE。 

flemtime0) 函 数 返回 指定 文件 flename 的 最 后 修改 时 间 ， 语 法 如 下 : 

int filemtime(string filename); 

如 成 功 则 返回 UNIX 时 间 戳 ， 和 否则 返回 FALSE。 
图 设计 过 程 

首先 设计 网 页 页 面 ， 然 后 创建 一 个 表单 ， 通 过 文件 域 提交 要 判断 的 文件 ， 接 着 获取 表单 中 提交 的 文件 路 径 ， 
应 用 flectime0 和 filemtime0 函 数 对 提交 的 文件 进行 检测 ， 最 后 输出 检测 结果 。 


index.php 文件 的 关键 代码 如 下 : 

<?php 

stle =iconv ( "utf-8", "gb2312",$ POST ['files] ): // 实 现 编码 格式 的 转换 

if (file_exists ( $file )) { 1/ 判断 文件 是 否 存在 
Schange_ time = filectime ( $file ); /获取 文件 的 最 后 incode 时 间 
Stime = date ( "Y-m-d hti:s", $change_time ); /时 间 戳 的 格式 化 
Slast_time = filemtime ( $file ); /获取 文件 的 最 后 修改 时 间 
Stimes = date ( "Y-m-d h:i:s", $last_time ); /时 间 恰 的 格式 化 

j else{ 
Sresult = "该 文件 不 存在 !1"; 

} 

> 

力 秘笈 心 法 


心 法 领悟 240: 获取 文件 的 最 后 访问 时 间 。 
通过 文件 系统 函数 不 但 可 以 获取 文件 的 最 后 修改 时 间 ， 而 且 可 以 获取 文件 的 最 后 访问 时 间 ， 其 应 用 的 是 
fileatimeO 函 数 。 


趣味 指数 : ON 


实例 241 


力 实例 说 明 
应 用 POST 方法 上 传 文件 时 ， 需 要 将 上 传 文件 保存 到 服务 器 指定 的 目录 中 ， 这 时 可 能 会 出 现 因 名 称 相同 而 
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文件 相互 蔡 换 的 情况 。 为 了 解决 上 述 问 题 ， 可 以 应 用 basename0 〇 函数 和 随机 函数 mt rand0 对 上 传 文件 进行 重新 
命名 。 在 本 实例 中 ， 成 功 上 传 一 个 文件 之 后 ， 将 弹出 新 的 文件 名 称 对 话 框 ， 如 图 4.21 所 示 。 


microsoft Internet Exzplorer x| 


企 文件 名 被 葵 换 为 724020100710082127 经 验 技巧 . rar 


[El 


图 4.21 重新 定义 上 传 文件 名 称 


图 关键 技术 


在 本 实例 中 ， 实 现 文件 上 传 的 功能 ， 有 关 文 件 上 传 的 技术 请 参考 实例 224， 这 里 不 再 歼 述 。 下 面 将 介绍 一 
种 给 上 传 文件 命名 的 方法 。 

basename() 函 数 返 回 指定 文件 目录 中 的 基本 文件 名 ， 语 法 如 下 : 

string basename(string path [, string suffix]) 

参数 path 指定 文件 的 路 径 ， 参 数 suffix 为 可 选 参数 ， 如 果 文 件 路 径 以 suffix 结尾 ， 那 么 这 部 分 内 容 将 被 
删除 。 

通过 该 函数 获取 到 上 传 文件 的 原始 名 称 ， 并 对 这 个 名 称 进行 重新 定义 ， 从 而 避免 再 将 文件 上 传 到 服务 器 时 
出 现 重 名 的 问题 。 


图 设计 过 程 
上 传 文件 的 具体 实现 步骤 可 以 参考 本 章 实例 224， 这 里 不 再 著述 。 


在 本 实例 中 ， 关 键 是 在 定义 上 传 文件 的 名 称 时 ， 应 用 随机 函数 mt_rand0、 时 间 戳 以 及 basename0 函 数 ， 其 


关键 代码 如 下 : 
Sdate=date("YmdHis"); 定义 随机 数 
S$filename=mt_rand(1000,9999).$date.basename($_FILES[up_picture'][‘name']): i 义 上 传 文件 名 称 
echo "<script>alert( 文 件 名 被 普 换 为 "$filename.");</script>"; 
$path="./upfile/".$filename: // 定 义 上 传 文件 名 称 和 存储 位 置 


国 秘笈 心 法 
心 法 领悟 241: 上 传 文件 原始 名 称 的 获取 。 


在 通过 表单 中 的 文件 域 提交 上 传 文件 时 ， 如 果 在 form 中 定义 了 enctype="multipart/form-data" 属 性 ， 那 么 在 
获取 上 传 文件 的 原始 名 称 时 必须 使 用 $_FILES 全 局 变量 ， 如 果 使 用 $_POST 是 获取 不 到 值 的 。 


四 实例 说 明 


设想 这 样 一 个 场景 ， 若 知道 某 个 网 站 中 一 个 文件 的 具体 路 径 ， 在 本 地 就 可 以 完成 对 这 个 文件 内 容 的 读 取 操 
作 , 这 将 是 一 件 多 么 有 趣 的 事情 。 本 实例 就 将 这 个 场景 变 为 现实 ,实现 读 取 远程 文件 的 功能 ,运行 结果 如 图 4.22 
所 示 。 


趣味 指数 : al 
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御 芒 碑 远程 文件 的 内 容 


运程 文件 地 址 : [http-W192.168.1.227/mr txt 


+( 路 径 、 文 件 名 称 必 须 是 英文 字符 审 》 


党 贞 运 直人 mms 时 


4.22 ” 读 取 远 程 文件 的 数据 


上 ED 说 明 : 此 功能 的 实现 会 有 诸多 的 阻碍 ， 例 如 ， 服 务 器 不 支持 文件 的 远程 操作 、 访 问 的 文件 不 具备 读 的 权限 
等 。 这 里 只 是 通过 这 个 实例 ， 告 诉 大 家 如 何 实现 远程 文件 的 访问 操作 。 如 果 服 务 器 支持 文件 的 远程 
访问 ， 那 么 会 有 一 定 的 安全 隐患 。 


图 关键 技术 
访问 远程 文件 应 用 fopen0 函 数 ， 只 要 将 其 参数 filename 的 值 设置 为 一 个 完整 的 URL 地 址 即 可 。 


.GEBg 技巧 : 在 PHP 中 ， 如 果 要 访问 远程 文件 ， 必 须 将 配置 文件 php.ini 中 的 参数 allow_url fopen 设置 为 开启 。 
allow_url fopen 参数 默认 是 开启 的 ， 允 许 打 开 HTTP 协议 和 FTP 协议 指定 的 远程 文件 ， 如 果 
allow_url fopen 设置 为 off， 则 不 允许 打开 远程 文件 ， 函 数 将 返回 FALSE。 


图 设计 过 程 
(1) 创建 ndex php 文件 。 首 先 设 计 网 页 页 面 ， 然 后 创建 一 个 表单 ， 通 过 文本 框 提交 要 访问 的 远程 文件 的 


地 址 ， 最 后 获取 表单 中 提交 的 远程 文件 路 径 ， 并 通过 header0 函 数 跳 转 到 read.php 文件 中 ,在 该 文件 中 完成 对 远 
程 文件 的 读 取 操作 。index.php 文件 的 关键 代码 如 下 : 


pl 

if($_POST ['files]!=""){ 

S$filenames=urlencode($ POST ['files"]); 
header("Location: read.php?filename=$filenames"); 
} 

?> 


(2) 创建 read.php 文件 ， 获 取 header() 函 数 传递 的 参数 值 ， 应 用 fleO) 函 数 读 取 参 数值 中 传递 的 远程 文件 ， 
并 通过 foreach 语句 输出 远程 文件 的 内 容 ， 其 代码 如 下 : 


<?php 

S$filename = iconv ( "utf-8", "gb2312", $_GET['filename'] ); // 获 取 header0 函 数 传递 的 参数 值 
S$arr = file ( $filename) ; // 读 取 远 程 文件 的 内 容 

foreach ( $arr as $value ) { // 循 环 输出 数据 


echo htmlspecialchars ( iconv ( "gb2312", "utf-8", $value ) )."<br>"; 
} 


图 秘笈 心 ; 
心 法 领悟 242: 不 被 看 好 的 远程 文件 访问 功能 。 


严格 地 说 ， 远 程 文件 的 访问 功能 有 时 是 不 被 支持 的 ， 因 为 它 涉及 服务 器 中 文件 的 安全 问题 ， 所 以 在 多 数 的 
服务 器 中 ，allow_url_fopen 的 值 都 是 关闭 的 。 
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实例 243 趣味 指教 : 请 良友 竣 家; 


力 实例 说 明 
在 本 实例 中 ， 将 完成 一 个 具体 的 操作 一 一 删除 指定 目录 下 的 所 有 .ini 文件 ， 其 运行 结果 如 图 4.23 所 示 。 


当前 目录 :F: \wanp\wesbpageWIR\D4\243 


项 目 名 大 小 创建 日 期 最 后 修改 时 间 操作 
锁定 目录 2015-01-20 16:39:10 2015-01-20 16:39:10 昨 | 余 
上 级 目录 目录 2014-02-12 13:17:52 2015-01-20 16:39:10 删除 
delete. php 408 2015-01-20 16:39:10 2010-07-07 11:46:08 aelete php 
INAGES 目录 2015-01-20 16:39:10 2015-01-20 16:39:10 INAGES 
index. php 5116 。 2015-01-20 16:39:10 C2010-07-07 11:28:14 index. php 
look file.php 876 2015-01-20 16:39:10 2010-07-07 11:25:46 look_file. php 
php. ini 0 2015-01-20 16:39:10 2010-07-07 11:26:44 星 余 
配置 文件 .ini 25 2015-01-20 16:39:10 2010-07-07 14:18:04 胜 除 


图 4.23 删除 指定 目录 下 的 所 有 .ini 文件 


图 关键 技术 


有 关 目 录 、 文 件 的 删除 方法 已 经 在 前 面 的 实例 中 讲解 过 ， 这 里 不 再 歼 述 。 删 除 指定 目录 下 特定 格式 文件 的 
实现 原理 与 删除 所 有 文件 相同 ， 只 是 在 创建 删除 链接 前 对 文件 的 格式 进行 判断 ， 如 果 文 件 是 .int 类 型 ， 那 么 就 输 
出 删除 的 超 链 接 ， 否 则 将 直接 输出 文件 的 名 称 ， 其 关键 代码 如 下 : 


Scatalog = getewd () . "\\$gain_directory"; // 子 目录 
$ext = substr ( $gain_directory, stmpos ( $gain_directory, "." ) ); /获取 文件 的 后 组 
证 (strtoupper ( $ext ) — "INI") { /判断 如 果 文 件 的 后 缀 是 .ini， 则 创建 删除 超 链接 
echo "<a href='delete.php?catalog=".urlencode($catalog)."&filename=" . urlencode(getewd 0) ." title=' 删 除 目录 或 者 文件 ' > 删除 </a>"; 
}else{ // 如 果 文件 的 后 缀 不 是 ini， 则 直接 输出 文件 名 称 
echo iconv ( "gb2312", "utf-8", $gain_directory ); 
} 
图 设计 过 程 


(1) 本 实例 index.php 文件 的 创建 过 程 与 遍历 、 删 除 指定 目录 下 的 所 有 文件 是 基本 相同 的 ， 不 同 之 处 已 经 
在 关键 技术 中 给 出 ， 这 里 不 再 次 述 。 
(2) 创建 look_file.php 文件 ， 完 成 对 .ini 后 缀 文件 的 读 取 操作 ， 其 代码 如 下 : 
Scatalog = iconv ( "utf-8", "gb2312", urldecode ( $_GET [catalog] ) ); 


Sfilename = iconv ( "utf-8", "gb2312", urldecode ($ GET [filename] ) ); $type =iconv ( "utf-8", "gb2312", urldecode ( $_GET [type] )); /获取 文件 
的 信息 ， 设 置 编码 


Sarr =file ( $catalog . "\" . $filename ); // 读 取 文 件 

foreach ( $arr as $value ) { /循环 输出 文件 内 容 
$value = htmlentities ( Svalue. ENT_COMPAT, "UTF-8" ): /| 特殊 字符 的 转换 
echo $value . "<br>": /输出 内 容 

} 

> 


(3) 创建 delete.php 文件 ， 完 成 对 指定 文件 的 删除 操作 ， 代 码 请 参考 本 书 光盘 。 
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图 秘笈 心 法 


心 法 领悟 243: 合理 地 运用 自己 的 编程 资源 。 

在 进行 程序 开发 的 过 程 中 ， 要 学 会 合理 地 运用 自己 的 编程 资源 。 一 个 好 的 功能 模块 ， 不 应 只 在 一 个 程序 中 
使 用 ， 还 应 具有 重用 价值 。 例 如 数据 库 的 连接 、 操 作 方法 以 及 分 页 技术 等 ， 一 次 开发 后 将 会 在 很 多 的 程序 中 使 
用 ， 避 免 对 类 似 程序 进行 重复 开发 ， 浪 费 不 必要 的 时 间 。 

作为 一 个 程序 员 ， 在 每 次 开发 时 不 仅 要 考虑 新 的 功能 、 新 的 技术 ， 更 重要 的 是 充分 运用 已 有 资源 ， 既 可 以 
提高 程序 的 开发 效率 ， 又 可 以 避免 开发 新 技术 产生 的 一 些 问题 。 

高 级 | 


实例 244 趣味 指数 : abodedobd 


力 实例 说 明 


文本 文件 中 的 数据 也 可 以 转 存 到 数据 库 中 。 例 如 ， 在 编程 词典 服务 网 中 ， 有 一 个 编程 词典 系列 软件 注册 信 
息 提 交 页 面 ， 在 该 页 面 中 ， 编 程 词典 用 户 不 但 提交 个 人 信息 ， 而 且 将 安装 编程 词典 生成 的 注册 信息 文件 提交 
到 服务 器 中 ， 在 提交 注册 信息 的 同时 ， 将 注册 信息 中 的 数据 与 用 户 个 人 信息 一 起 存储 到 数据 库 中 。 本 实例 模拟 
这 个 功能 ， 开 发 一 个 将 文本 文件 上 传 到 服务 器 ， 并 且 将 文本 文件 中 的 数据 转 存 到 数据 库 中 的 实例 ， 其 运行 结果 
如 图 4.24 所 示 。 


图 关键 技术 


本 实例 运用 了 3 方面 的 技术 : 第 一 ， 将 文本 文件 上 传 到 服务 器 ， 第 二 ， 读 取 服 务 器 指定 文件 夹 下 文本 文件 
中 的 数据 ， 第 三 ， 连 接 数 据 库 ， 将 从 文本 文件 中 读 取 的 数据 存储 到 指定 数据 表 中 。 
EE E23N SE EE 
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9 5 有 
图 4.24 将 文本 文件 存储 到 数据 库 中 


其 中 ， 最 关键 的 是 将 文本 文件 中 的 数据 存储 到 数据 库 中 ， 在 执行 数据 的 读 取 和 存储 时 ， 有 两 个 细节 必须 把 
握 。 第 一 个 ， 应 用 addslashes() 函 数 ， 对 从 文本 文件 中 读 取 的 数据 进行 转 义 ， 因 为 在 读 取 的 数据 中 可 能 包含 单 引 
号 () 、 双 引号 (") 、 反 斜 线 (\) 或 者 NUL (NULL 字符 ) ， 如 果 不 对 其 进行 转换 ， 在 执行 SQL 语句 时 可 
能 会 出 现 错误 。 

addslashes() 函 数 通 过 反 斜 线 来 引用 字符 串 ， 语 法 如 下 : 


string addslashes ( string str) 


在 其 返回 的 字符 串 中 ， 为 了 数据 库 查询 语句 等 的 需要 在 某 些 特 定 字符 前 加 上 了 反 和 斜 线 ， 这 些 特定 字符 包括 
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单 引号 (') 、 双 引号 (") 、 反 斜 线 (\) 和 NUL (NULL 字符 ) 。 


上 加 说 明 : 默认 情况 下 ， 


了 PHP 指令 会 自动 对 所 有 的 GET、POST 和 COOKIE 数据 运行 addslashes0 函 数 。 所 以 ， 


如 果 是 通过 GET 或 者 POST 方法 提交 的 数据 是 不 需要 进行 转 义 的 ， 可 以 直接 添加 到 数据 库 中 ; 如 果 
提交 的 数据 是 从 文本 文件 中 读 取 或 者 自 定义 的 内 容 ， 那 么 就 有 必要 对 其 进行 转 义 。 


图 设计 过 程 


(1) 创建 index.php 文件 。 首先 设 计 网 页 页 面 , 然后 创建 一 个 表单 ， 通过 文件 域 提交 要 上 传 的 .ini 文件 。 
接着 获取 表单 中 提交 的 文件 ， 将 文件 存储 到 服务 器 指定 的 文件 夹 下 ， 通 过 file_ get_contents0) 函 数 读 取 上 传 文件 
的 内 容 ， 并 且 将 读 取 的 结果 存储 到 指定 的 数据 表 中 。 最 后 执行 查询 语句 ， 输 出 数据 库 中 存储 的 .ini 文件 的 内 容 ， 


其 关键 代码 如 下 : 


<?php 


if(! empty ($_FILES [up_picture] [name] ) { // 判 断 上 传 内 容 是 否 为 空 
$type =$_FILES [up_picture] [name']; 


Stypes = strstr ( $type,  ); // 获 取 文件 后 缀 
if ($types — "ini") { 
if($_FILES [up_picture] ['error] > 0) { 1/ 判断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错误 :"; 
switch ($_FILES [up_pieture] [error]) { 
case 1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break: 
case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break: 
case 3: 
echo "上 传 文件 不 全 ": 
break: 
case 4: 
echo "没有 上 传 文件 ": 
break: 
4 
}else{ 
if(lis_dir ("./upfile/")) { // 判 断 指定 目录 是 否 存在 
mkdir ( "upfile/" ); // 创 建 目录 
} 
Sfile_name = time () . strstr ( $_FILES [up_picture] [name'], ' ): // 定 义 上 传 文件 名 称 
$path ="./upfile/" . $file_name; // 定 义 上 传 文件 名 称 和 存储 位 置 
if(is_uploaded file ( $_FILES [mp_picture] [tmp_name])){ 1/ 判断 文件 是 否 通过 HTPP POST 上 传 
让 (! move_uploaded_file ( $_FILES [up_picture] [tmp_name]. $path )) { /执行 上 传 操作 
echo "上 传 失败 "; 
}else{ 
// 读 取 文 本 文件 中 的 数据 ， 并 且 实 现 转 义 和 编码 的 转换 
Sarr = iconv ( "gb2312", "utf-8", addslashes ( file get contents ($path ) ) ): 
include_once ("conn/conn.php"): // 连 接 数据 库 
$sql = "insert into tb_files(file_name,file_content.file_date)values('$file_name','$ar,” . date ("Y-m-d Hii:s" ) . ")"; 
// 定 义 SQL 添加 语句 
Sresult = mysql_ query ( $sql, $conn ); // 执 行 添加 操作 
echo "文件 ，" .$_FILES [up_picture] [name'] . ”上 传 成 功 !" . "<br>"; 
echo "大 小 : " .$_FILES [up_picture] [size] ." 字 节 ": 
} 
}else { 
echo "上 传 文件 " . $_FILES [up_pictute] [name'] . "不 合法 ! "; 
} 
} 
}else { 


echo "上 传 文件 " .$_FILES [up_pictute] [name] . "类 型 不 正确 ! "; 


} 
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} 


> 
(2) 创建 conn 文件 夹 , 编写 conn php 文件 ,连接 数据 库 服务 器 ,连接 db_database04 数据 库 , 其 代码 如 下 : 
SIphp 


$conn = mysql_connect ( "localhost", "root", "111" ) or die ("连接 数据 库 服 务 器 失败 !" . | error 0 ): 
mysql_select_db ( "db_database04", $conn ); /| 选择 数据 库 db_database04 
mysql_query ( "set names utf8" ); /设置 数据 库 编码 格式 UTF-8 
?> 

图 秘 笈 心 法 


心 法 领悟 244: addslashes0 转 义 函数 的 合理 运用 。 
将 从 文本 文件 中 读 取 的 数据 存储 到 数据 库 时 , 必须 应 用 addslashesO 函 数 对 文本 文件 返回 的 字符 串 进 行 转 义 
否则 有 可 能 出 现 如 图 4.25 所 示 的 错误 。 


a i 
numan 一 一 一 el 低下 动 
上 传 文件 类 型 为 ( jini》 


You have an emor in your SQL syntax, check the manual that comesponds to your MySQL server version for the right syntaxto 
ae near 's behuvior. In order for PHP to ,read it, it must be mamed ‘php ini, PHP Jo at line 1 


图 4.25 数据 添加 失败 
4.5 文件 的 压缩 与 解压 
WinRAR 是 一 个 非常 实用 的 文件 压缩 管理 工具 ， 利 用 其 强大 的 功能 可 以 很 方便 地 将 多 个 文件 压缩 成 为 一 个 


文件 ， 这 样 不 仅 可 以 方便 操作 ， 而 且 可 以 在 很 大 程度 上 节省 文件 存储 的 空间 。 本 节 将 向 读者 介绍 如 何 利 用 PHP 
解压 缩 和 解压 缩 文 件 。 


| 


高 级 


实例 245 趣味 指数 : 但 食 食 食 合 


国 实例 说 明 


在 网 站 中 ， 上 传 的 文件 多 数 都 是 以 压缩 包 的 形式 存在 的 ， 所 以 先 将 要 上 传 的 文件 压缩 后 才能 够 上 传 ， 如 果 
能 在 网 站 中 增加 上 传 文件 自动 压缩 模块 ， 将 会 给 用 户 带 来 很 大 的 方便 。 本 实例 将 向 读者 介绍 如 何在 PHP 中 完成 
文件 的 压缩 操作 。 运 行 本 实例 ， 首 先 选择 要 压缩 的 文件 ， 然 后 设置 压缩 文件 的 存储 位 置 ， 单 击 “ 提 交 ” 按 钮 ， 


运行 结果 如 图 4.26 所 示 。 


指定 压缩 文件 : 司 WppServvrm ER\04\005\ 条 建文 于 
定义 压 贸 文件 存 全 位 置 : WAppServiwre WRVD4V025\ 茜 过 文 件 夫 ”提交 


设置 压 芝 文件 存储 位 置 ( 全 各 : 《FAAppSerwrwwiMR04025) 9 
De 
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图 4.26 RAR 压缩 文件 


PHP 开发 实例 大 全 (基础 卷 ) 


图 关键 技术 


文件 压缩 主要 应 用 PHP 的 预定 义 类 com， 将 wscript.shell 对 象 作为 com 类 的 参数 ， 最 终 通过 调用 com 类 的 
run0 方 法 实现 文件 的 压缩 。 
com 类 提供 一 个 将 COM 组 件 整合 到 PHP 脚本 中 的 框架 ， 实 例 化 方法 如 下 : 


Sobj =new COM("server.object") 


com 类 构造 函数 的 语法 如 下 : 
string COM::COM ( string module name[ string server name [, int codepage]] ) 


参数 说 明 : 

module_ name: 被 请 求 组 件 的 名 字 或 class-id。 

server name: DCOM 服务 器 的 名 字 ， 组 件 在 此 服务 器 上 被 取 用 。 如 果 是 NULL， 则 假定 是 localhost。 如 果 
要 支持 允许 DCOM， 必 须 将 php.ini 中 的 com.allow_dcom 设 为 TRUE。 

codepage: 指定 用 于 将 PHP 字符 串 〈php-strings) 转换 成 UNICODE 字符 串 〈unicode-strings) 的 代码 页 ， 
反之 亦 然 。 可 用 的 值 为 CP_ACP、CP_MACCP、CP_OEMCP、 CP_SYMBOL、 CP_THREAD _ACP、CP_UTF7 和 
CP_UTF8。 

com 类 中 run0 方 法 的 语法 如 下 : 

run("winrar a 生成 的 rar 文件 的 路 径 及 名 称 要 压缩 的 文件 的 路 径 及 名 称 ",1 ,false); 
图 设计 过 程 

(1) 创建 index.php 文件 。 首 先 创 建 一 个 表单 ， 设 置 文件 域 ， 提 交 要 压缩 的 文件 ， 设 置 文 本 框 ， 提 交 压 缩 
文件 的 存储 位 置 ， 设 置 按钮 ， 完 成 表单 元 素 的 提交 操作 。 

(2) 在 index.php 文件 中 编写 PHP 脚本 ， 通 过 $_POST 方法 获取 表单 提交 的 数据 ， 通 过 iconv0 函 数 完成 数 
ek 实例 化 com 类 ， 调 用 run0 方 法 完成 文件 的 压缩 操作 ， 其 关键 代码 如 下 : 


民 POST [Submit] ="") { 


$sourcefile = iconv ( "utf-8", "gb2312", $_POST [sourcefile] ); /获取 指定 文件 的 路 径 

$objfile = $_POST [objfile] . "\" .time 0: /定义 压缩 文件 的 存储 位 置 和 名 称 
$objfile = iconv ( "utf-8", "gb2312", $objfile ): /实现 编码 转换 

$obj = new com ( "wscript.shell" ); // 实 例 化 com 类 

S$obj->run ( "winrar a " . $objfile . " " . $sourcefile . "", 1, false ); /调用 类 中 的 方法 


echo "<script>alert( 文 件 压缩 完成!):</script>"; 


> 


力 秘笈 心 法 


心 法 领悟 245: 执行 文件 压缩 操作 的 误区 。 
在 执行 文件 压缩 操作 时 ， 切 鼠 在 文件 的 存储 路 径 中 出 现 空格 〈 包 括 被 压缩 文件 的 路 径 、 名 称 以 及 压缩 文件 
的 存储 路 径 ) ， 否 则 压缩 操作 将 不 会 正确 执行 。 


We 


高 级 
实例 246 起 叶 相 娄 : oodoled 
图 实例 说 明 


在 本 实例 中 ， 实 现 将 上 传 的 文件 直接 以 压缩 文件 的 格式 进行 存储 ， 其 好 处 是 可 以 缓解 服务 器 的 压力 、 节 省 
服务 器 的 空间 。 运 行 本 实例 ， 选 择 要 上 传 的 文件 ， 单 击 “提交 ”按钮 ， 运 行 结果 如 图 4.27 所 示 。 
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选择 上 传 文件 : EDocwments and SettingsVdnin 攻守 开 提交 


文件 : createxamlhttp js 上 传 成 功 9 
大 小 : 342 字 节 
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图 4.27 将 上 传 文件 转换 成 压缩 文件 
上 传 成 功 后 ， 可 以 查看 本 实例 根 目录 下 的 upfile 文件 夹 ， 确 定 上 传 文件 是 否 以 压缩 文件 的 格式 进行 存储 。 
图 关键 技术 


本 实例 实现 文件 上 传 技术 与 文件 压缩 技术 的 结合 ， 从 而 实现 将 上 传 文件 以 RAR 格式 进行 存储 。 其 中 在 
调用 com 类 中 的 run() 方 法 执行 压缩 操作 时 ， 在 winrar 的 命令 中 ， 增 加 了 两 个 属性 : “-ep ”表示 将 压缩 文 
件 以 文件 名 的 格式 进行 存储 ， 不 包括 文件 的 路 径 ，“-df” 表 示 文 件 压缩 成 功 后 删除 原始 文件 ， 其 完整 的 命 
令 语句 如 下 : 

$obj->run ( "winrar a -ep -df " . $file_path.".rar" ."" . $path . "", 1, false ); // 调 用 类 中 的 方法 ， 执 行文 件 压 缩 操 作 
力 设计 过 程 

(1) 创建 index.php 文件 。 首 先 创建 一 个 表单 ， 设 置 文件 域 ， 提 交 上 传 文件 ， 设 置 按钮 ， 完 成 表单 元 素 的 
提交 操作 。 

(2) 在 index.php 文件 中 编写 PHP 脚本 。 首 先 对 上 传 文件 进行 判断 ， 如 果 符合 要 求 将 上 传 文件 存储 到 服务 
器 指定 文件 夹 下。 然后 实例 化 PHP 中 的 com 类 ， 通 过 run0 方 法 执行 文件 的 压缩 命令 ， 完 成 上 传 文件 的 压缩 操 


作 ， 并 将 原始 文件 删除 ， 其 关键 代码 如 下 : 
// 定 义 上 传 文件 名 称 和 存储 位 置 
$path ="./upfile/", time () . strstr ( $ FILES Tsourcefile1 f'name'l, *): 


if (is_uploaded_file ( $_FILES [sourcefile] ['tmp_name’] )) { 
if(! move_uploaded _file ( $_FILES ['sourcefile'] [tmp_name], $path )) { echo "上 传 失败 "; 
Yelsef 
Spath = realpath ( iconv ( "utf-8", "gb2312", $path ) ); // 获 取 文 件 在 服务 器 中 的 路 径 
Slen = strripos ( $path, "." ); 1/ 计算 路 径 的 长 度 
S$file_path = substr ( $path, 0, Slen ); /获取 上 传 文件 的 路 径 名 称 


S$obj = new com ( "wscriptshell" ); /实例 化 com 类 
1/ 调 用 类 中 的 方法 ， 执 行文 件 压缩 和 原始 文件 删除 操作 
S$obj->run ( "winrar a -ep -df " . $file_path. ".rar” ." " . $path . "", 1, false ): 
echo "文件 :" . $_FILES [sourcefile] [name] . "上 传 成 功 ! " . "<br>"; 
echo "大 小 :" . $_FILES [sourcefile] [size] .” 字 节 ": 
}else . 
echo "上 传 文件 " . $_FILES ['sourcefile'] [name] . "不 合法 !"; 
| 


四 秘笈 心 法 


心 法 领悟 246: winrar 操作 命令 的 运用 。 
对 RAR 文件 进行 操作 的 命令 , 不仅 有 rt、-ep 和 -df 这 3 个 , 还 有 很 多 ,读者 可 以 参考 RAR 用 户 手 册 了 解 更 
多 关于 RAR 操作 的 命令 。 
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实例 247 


图 实例 说 明 


既然 已 经 介绍 了 如 何 对 文件 进行 压缩 ， 那 么 必然 要 介绍 如 何 对 压缩 文件 进行 解压 。 运 行 本 实例 ， 首 先 选择 
要 解压 的 RAR 文件 ， 并 在 文本 框 中 输入 要 解压 文件 的 存储 目录 ， 单 击 “ 解 压 ”按钮 即 可 ， 运 行 结果 如 图 4.28 
所 示 。 


指定 压缩 文件 : 克 WAppServ ww WR\04\026\upEile EM 
定义 解压 文件 存储 位 置 : 克 WAppServwww WHR\04\027 | 解压 
设置 压缩 文件 存储 位 置 《 例如 ;《 FAppServwwwiMRI04027) 9 
各 1 CopyRiehts © reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.28 解压 RAR 文件 


力 关键 技术 


文件 解压 同样 应 用 PHP 的 预定 义 类 com, 将 wscript.shell 对 象 作为 com 类 的 参数 , 通过 调用 com 类 的 run() 


方法 执行 文件 解压 的 命令 。 文 件 解 压 的 命令 如 下 : 
Sobj->mn ( "winrar x -av -ce ".$soureefile." ".$objfile. mw, 1, true ); /调用 类 中 的 方法 ， 执 行文 件 解压 的 命令 


通过 此 命令 将 指定 的 压缩 文件 解压 到 指定 的 绝对 路 径 下 。 
图 设计 过 程 

(1) 创建 index.php 文件 。 首 先 ， 创 建 一 个 表单 ， 设 置 文 件 域 ， 提 交 要 解压 的 文件 ， 设 置 文 本 框 ， 提 交 解 
压 后 文件 的 存储 位 置 ， 设 置 按钮 ， 完 成 表单 元 素 的 提交 操作 。 


(2) 在 index.php 文件 中 编写 PHP 脚本 ， 通 过 $_POST 方法 获取 表单 提交 的 数据 ， 通 过 iconv0 函 数 完成 数 
据 编码 格式 的 转换 ， 实 例 化 com 类 ， 调 用 run0 方 法 执行 文件 的 解压 命令 ， 其 关键 代码 如 下 : 


<Iphp 
if($_POST [Submit] = "") { 


include("function.php"): 

$sourcefile = iconv ( "utf-8", "gb2312", unhtml($_POST ['sourcefile]) ): /获取 指定 文件 的 路 径 

Sobjfile = iconv ( "utf-8", "gb2312", $_POST [objfile] ): /定义 解压 文件 的 存储 位 置 和 名 称 
$obj = new com ( "wscriptshell" ); /实例 化 com 类 

S$obj->run ( "winrar x -av -c ".$sourcefile." ".$objfile. "", 1. true ); // 调 用 类 中 的 方法 ， 执 行 解压 命令 


echo "<script>alert(' 文 件 解压 完成 !):</script>"; 
} 
> 


力 秘笈 心 ; 
心 法 领悟 247: 执行 文件 解压 操作 的 误区 。 


在 执行 文件 解压 操作 时 ， 切 鼠 在 文件 的 存储 路 径 中 出 现 空格 〈 包 括 被 解压 文件 的 路 径 、 名 称 以 及 解压 后 文 
件 的 存储 路 径 ) ， 否 则 解压 操作 将 不 会 正确 执行 。 
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实例 248 


力 实例 说 明 


通过 PHP 不 但 可 以 将 文件 压缩 成 RAR 格式 , 而 且 可 以 将 文件 压缩 成 ZIP 格式 , 本 实例 将 介绍 如 何 应 用 PHP 
将 文件 压缩 成 ZIP 格式 。 运 行 本 实例 ， 首 先 选 择 要 压缩 的 文件 ， 然 后 设置 压缩 文件 的 存储 位 置 ， 单 击 “ 提 交 ” 
按钮 即 可 ， 运 行 结果 如 图 4.29 所 示 。 


wana (rr 


设置 ZIP 压 移 文 件 存储 位 置 ( 例如 :《 FWAppServwwwiMRW4028w zip ) 4 
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图 4.29 ZIP 压缩 文件 


力 关键 技术 


运用 PHP 将 文件 压缩 成 ZIP 格式 的 原理 与 压缩 成 RAR 格式 的 原理 相同 : 首先， 运用 PHP 的 预定 义 类 com 
调用 系统 中 安装 WinRAR 后 所 形成 的 组 件 wscriptshell， 并 对 com 类 进行 实例 化 。 然 后 ， 调 用 com 类 中 的 run0 
方法 执行 文件 的 压缩 命令 。 对 com 类 进行 实例 化 及 调用 类 中 rmn0 方 法 的 代码 如 下 : 
S$obj=new com("wscript.shell"); 
Sobj->run("winrar a ",Sobjfile." ".Ssourcefile.™", 1,false); 
力 设计 过 程 
(1) 创建 index.php 文件 。 编 写 form 表单 ， 提 交 被 压缩 文件 和 压缩 文件 的 存储 位 置 及 名 称 。 
(2) 在 index.php 文件 中 编写 PHP 脚本 ， 通 过 $_POST 方法 获取 表单 提交 的 数据 ， 通 过 iconv0) 函 数 完成 数 
据 编码 格式 的 转换 ， 实 例 化 com 类 ， 调 用 run0 方 法 完成 文件 的 压缩 操作 ， 其 关键 代码 如 下 : 


<2php 
if($_POST ['Submit] ="") { 


$sourcefile = iconv ( "utf-8", "gb2312", $_ POST [sourcefile] ); /获取 指定 文件 的 路 径 
$objfile = iconv ( "utf-8", "gb2312", $_ POST [objfile] ): /| 实现 编 码 转换 
S$obj = new com ( "wscriptshell" ): // 实 例 化 com 类 
Sobj->run ( "winrar a -ep " . $objfile . " " . $sourcefile . "", 1, false ); // 调 用 类 中 的 方法 ， 执 行文 件 压缩 操作 
echo "<script>alert( 文件 压缩 完成 !):</script>": 

} 

?> 

国 秘笈 心 ; 


心 法 领悟 248: 将 上 传 文件 转换 成 ZIP 文件 。 
将 上 传 文件 转换 成 ZIP 文件 与 将 上 传 文件 转换 成 RAR 文件 相同 ， 都 是 运用 winrar 中 a、-ep 和 -df 命令 ， 具 
体 步 骤 可 以 参考 实例 247。 
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实例 249 


力 实例 说 明 


既然 可 以 完成 ZIP 文件 的 压缩 , 那么 一 定 也 可 以 实现 对 ZIP 文件 的 解压 操作 。 本 实例 将 介绍 如 何 实现 对 ZIP 
文件 的 解压 。 运 行 本 实例 ， 首 先 选择 要 解压 的 ZIP 文件 ， 并 在 文本 框 中 输入 要 解压 文件 的 存储 目录 ， 单 击 “ 解 
压 ” 按 钮 即 可 ， 运 行 结果 如 图 4.30 所 示 。 


”全 驱 迎 末 到 
Cx 


选择 ZIP 压 缩 文件 : 攻 W 
定义 解压 文件 存储 位 置 : 大 
设置 解压 文件 存储 位 置 ( 例如 : (FWAppServiwwwiMR04029 ) 9 

加 1 CopyRiehts © reserved 2010 吉林 省 明日 科技 有 限 公司 


图 4.30 ”ZIP 文件 解压 


图 关键 技术 

解压 ZIP 文件 同样 应 用 PHP 的 预定 义 类 com， 具 体 参考 实例 247 的 关键 技术 部 分 。 
力 设计 过 程 

具体 设计 过 程 请 参见 实例 247。 
国 秘笈 心 法 


心 法 领悟 249: 解压 ZIP 文件 时 ， 压 缩 文件 和 解压 文件 的 存储 路 径 中 不 可 以 有 空格 。 
在 执行 解压 ZIP 文件 的 操作 时 ， 压 缩 文 件 和 解压 文件 的 存储 路 径 中 不 可 以 有 空格 ， 即 不 允许 出 现 
C:\Documents and Settings\ 或 者 E:\Program Files\ 此 类 目录 ， 否 则 解压 操作 将 不 能 正确 执行 。 


4.6 目录 操作 


在 网 站 的 服务 器 上 ， 目 录 是 必 不 可 少 的 ， 因 为 它 可 以 把 文件 进行 分 类 存放 ， 方 便 管 理 者 查找 ， 所 以 对 目录 
进行 在 线 管理 是 非常 必要 的 。 


高 级 | 
实 斧 
实例 说 明 
在 前 面 的 实例 中 ， 已 经 涉及 很 多 目录 操作 的 方法 ， 如 创建 目录 、 获 取 当前 目录 、 删 除 目录 等 。 在 本 实例 中 ， 
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将 对 目录 的 基本 操作 进行 一 次 汇总 ， 使 读者 对 目录 操作 方法 有 个 系统 的 了 解 。 运 行 本 实例 ， 可 以 实现 目录 的 创 
建 、 浏 览 和 删除 操作 ， 其 运行 结果 如 图 4.31 所 示 。 


- 


戏 迎 来 到 明日 又 件 管理 系统 1! 
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图 4.31 目录 操作 汇总 


图 关键 技术 


本 实例 主要 应 用 mkdir0、is_dir0、getewd0、rmdir0、opendir0 和 readdir0 函 数 等 ， 完 成 目录 的 判断 、 创 建 、 
打开 、 读 取 和 删除 操作 。 所 使 用 函数 的 功能 和 语法 如 表 4.2 所 示 。 


表 4.2 目录 操作 函数 汇总 
功 能 


新 建 一 个 由 pathname 指定 的 目录 。 参 数 mode 指定 目录 的 模式 ， 
mkdir0 ”| bool mkdir(string pathname [. int mode]) ”| 在 Windows 下 被 忽略 、 自 PHP 4.2.0 起 成 为 可 选项 。 默认 的 
mode 是 0777， 意 味 着 最 大 可 能 的 访问 权 


is dirO | boolis oris Carine miene) | | ooris irCarine fierame | 和 时 六 人 各 雁 丰 关上 为 好 则 返回 TRUE。 如 果 flename 是 
一 个 相对 路 径 ， 则 按照 当前 工作 目录 检查 其 相对 路 径 

getcwd0 返回 当前 的 工作 目录 

删除 dimame 所 指定 的 目录 。 该 目录 必须 是 空 的 , 而 且 要 有 相应 
的 权限 。 如 果 成 功 则 返回 TRUE， 失 败 返 回 FALSE 
打开 一 个 目录 句柄 ， 如 成 功 返 回 目录 句柄 的 resource， 失 败 则 返 
回 FALSE。 返 回 值 可 用 于 closedir0、readdir0 和 rewinddirO 函 数 
resource opendir ( string path [. resource | 中 。 如 果 参 数 path 不 是 一 个 合法 的 目录 或 者 因为 权限 限制 或 文件 
context] ) 系统 错误 而 不 能 打开 目录 ，opendir0 返回 FALSE 并 产生 一 个 
E_WARNING 级 别 的 PHP 错误 信息 。 可 以 在 opendir0 前 面 加 
上 “@” 符 号 来 抑制 错误 信息 的 输出 

从 目录 句柄 中 读 取 条 目 ， 如 成 功 则 返回 目录 中 下 一 个 文件 的 文件 
Teaddir0 | string readdir ( resource dir handle ) 名 , 否则 返回 FALSE。 其 参数 dir handle 是 目录 句柄 的 resource， 
之 前 由 opendir0 打开 


Imdir0 bool rmdir ( string dirname ) 


opendir() 
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图 设计 过 程 

(1) 创建 index.php 文件 。 通 过 switch 语句 编写 一 个 网 页 框架 ， 根 据 超 链接 中 传递 的 参数 值 ， 在 index.php 
页 面 中 完成 创建 目录 、 浏 览 目录 、 删 除 目录 和 删除 文件 功能 之 间 的 跳 转 ， 其 关键 代码 如 下 : 

switeh ($_GET [dir]) { 

case "create" : 


include ("create.php"); 
break: 


case "look" : 
inelude ("look.php"): 
break: 


case "deletedir" : 
include ("deletedir.php"); 
break: 


case "deletefile" : 
include ("deletefile.php"); 
break; 

default : 
include ("look.php"); 
break; 


上 


?> 
(2) 创建 create.php 文件 ， 应 用 mkdir0 函 数 完成 目录 的 创建 ， 其 关键 代码 如 下 : 
<?php 
if($_POST [Submit] ="") { 
Sfile_dir =iconv ( "utf-8", "gb2312", $_POST ['objfile’] ); 
if(is_dir ( Sfile_dir)) { 
echo "<script>alert(' 目 录 已 经 存在 !");</script>"; 
}else { 
if (mkdir ($file_dir)) { 
echo "<script>alert(' 目 录 创 建成 功 !");</script>"; 
}else{ 
echo "<script>alert(' 目 录 创 建 失败 !");</script>"; 
} 
} 
} 


> 

(3) 创建 look.php 文件 ， 通 过 getewd0 函 数 定位 到 当前 目录 ， 并 应 用 opendir0 函 数 和 readdir0) 函 数 读 取 当 
前 目录 中 的 内 容 ， 其 代码 请 参考 本 书 光 盘 。 

(4) 创建 deletedir.php 文件 ,在 look.php 文件 的 基础 上 ， 为 输出 的 目录 创建 删除 超 链接 ,链接 到 delete.php 
文件 ， 完 成 目录 的 删除 操作 。 

(5) 创建 deletefile.php 文件 , 在 look.php 文件 的 基础 上 , 为 输出 的 文件 创建 删除 超 链 接 , 链接 到 delete.php 
文件 ， 完 成 文件 的 删除 操作 。 

(6) 创建 delete.php 文件 ， 分 别 应 用 rmdir0 函 数 和 unlink0 函 数 完成 目录 和 文件 的 删除 。 


国 秘笈 心 法 
心 法 领悟 250: 目录 的 删除 。 


在 应 用 rmdir0 函 数 删除 指定 的 目录 时 , 被 删除 的 路 径 必须 指向 空 的 目录 , 并 且 该 目录 的 权限 必须 合乎 要 求 ， 
否则 将 返回 FALSE。 
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趣味 指教 : 祷 良 雪 雪 家: 


力 实例 说 明 


在 对 网 站 进行 管理 和 维护 的 过 程 中 ， 经 常会 修改 文件 夹 的 名 称 ， 这 也 是 目录 的 一 项 基本 操作 。 本 实例 将 介 
绍 更 新 目录 名 称 的 方法 。 运 行 本 实例 ， 单 击 当前 目录 中 文件 夹 后 的 “ 重 命名 ” 超 链 接 ， 将 进入 如 图 4.32 所 示 的 
页 面 ， 在 这 个 页 面 中 完成 对 指定 目录 的 重 命名 操作 。 


I Gy 
rs 


原 目录 名 称 : |F:\AppSerAwwwwWWMIRWD4WD31\ 新 建文 件 夫 提交 
新 目录 名 称 : [ App Sor ai 
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图 4.32 执行 目录 的 重 命名 


图 关键 技术 

目录 的 重 命名 同样 应 用 的 是 rename0 函 数 ， 有 关 重 命名 的 技术 请 参考 实例 234。 
图 设计 过 程 

(1) 创建 index.php 文件 。 输 出 当前 目录 的 文件 和 目录 信息 ， 并 且 为 输出 的 目录 创建 “ 重 命 名 ” 超 链接 ， 

其 传递 的 参数 是 指定 目录 的 存储 位 置 和 当前 目录 的 位 置 ， 其 关键 代码 如 下 : 

<table width="650" border="0" cellspacing="0" cellpadding="0"> 

Ee <td width="50" height="23">&enbsp:</td> 
<td width="450"><span class="STYLE1"> 当 前 目录 : <?php echo getewd 0; 。 ?></span></td> 


<ltr> 
< 


<td> 


Slookdir = getewd 0: 
$i=0; 
if(is_dir ( $lookdir )) { 
if ($opendir = opendir ( $lookdir )) { 
while (Si = readdir ( Sopendir ) ) { 


<td height="23">&nbsp:</td> 
<td> 


Si++; 
echo " $i: "iconv ( "gb2312" "utf-8", Sli); 


<td> 


<aphp 


i 
echo "&nbsp:&nbsp": 
} elseif (filetype ($li ) — "file") { 
echo "&nbsp:&nbsp:": 
}else{ 


Scata = getewd 0 . "\" . iconv ( "gb2312", "utf-8", $li ); 


/获得 当前 脚本 目录 


/检测 是 否 为 合法 目录 
/打开 目录 
// 读 取 目 录 
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> 
<a href="rename.php?catalog=<?php echo urlencode ( $cata ): ?>&dir name=<?php echo urlencode ( getewd 0 ):?>"title=" 更 新 目录 名 称 " 
target=" blank"> 重 命名 </a> 


Aphp} > 
<ltd> 

< 
Ep 
</table> 


(2) 创建 rename.php 文件 ， 根 据 超 链接 传递 的 参数 值 创建 form 表单 ， 完 成 目录 的 重新 命名 提交 ， 并 且 在 
rename.php 文件 中 完成 重 命名 的 操作 ， 其 关键 代码 如 下 : 


<Iphp 
计 ($_POST['Submit] 一 "提交 ") { 


S$old_name=iconv("utf-8","gb2312",$_POST['old_name"]); 1/ 获取 原始 目录 名 称 
Snew_name=iconv("utf-8","gb2312",$_POST['new_name"]); 1/ 获取 新 目录 名 称 
if (file_exists ( $old_name)) { 
if(rename ( $old_name, $new name )) { // 把 原 目录 重新 命名 
echo "<script>alert(' 目 录 重 命名 成 功 ! 9): windowlocation href='index.php';</script>"; 
yelse{ 
echo "<script>alert(' 目 录 重 命名 失败 ! 9): window.location href='rename.php';</script>"; 
} 
}else{ 
echo "<script>alert(' 目 录 不 存在 ! ); window.location href="index.php';</script>"; 
} 
} 
> 
力 秘笈 心 法 


心 法 领悟 251: 超 链 接 中 参数 值 的 传递 技巧 。 
在 通过 超 链接 的 参数 向 下 一 个 页 面 中 传递 值 时 ， 最 佳 的 方法 就 是 应 用 urlencode0 函 数 对 参数 值 进行 编码 ， 其 最 
大 的 优点 是 可 以 避免 传递 中 文字 符 串 或 者 空格 时 出 现 乱码 ， 同 时 还 隐藏 了 传递 的 参数 值 ， 有 一 定 的 保护 作用 。 


ee . 2 
实例 趣味 指数 : 全食 从 
用 实例 说 明 


通过 文件 系统 函数 不 但 可 以 对 目录 、 文 件 进行 操作 ， 获 取 目 录 、 文 件 的 相关 信息 ， 而 且 可 以 获取 磁盘 分 区 
的 大 小 。 运 行 本 实例 ， 将 根据 文本 框 提交 的 目录 ， 获 取 该 目录 所 在 磁盘 分 区 的 大 小 ， 以 及 该 目录 下 的 所 有 文件 。 


运行 结果 如 图 4.33 所 示 。 
rr 


文件 各 称 : Me 
请 输入 正确 的 目录 5 全 0 : Fitwebpsgeipip ) 9 
本 说 磺 鳃 ( F ) 总 大 个 : 23GB 可 用 空间 : 1130 GB 
FMAppSeyibnwwMFVO4O17 目录 下 的 内 容 : 
1 
2 


3: ndexphp 
AIMAGES 
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图 4.33 ”获取 磁盘 分 区 的 大 小 
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图 关键 技术 


获取 磁盘 分 区 大 小 应 用 的 是 disk total space0 函 数 ; 获取 磁盘 分 区 剩余 空间 应 用 的 是 disk_free_space0 函 数 。 
disk total space0 函 数 获取 一 个 目录 的 磁盘 总 大 小 ， 语 法 如 下 : 
float disk_ total space ( string directory ) 
该 函数 根据 参数 directory 提供 的 一 个 目录 字符 串 ， 返 回 相应 的 文件 系统 或 磁盘 分 区 的 所 有 字 节 数 。 
< 注意 : 本 函数 不 能 作用 于 远程 文件 ， 被 检测 的 文件 必须 通过 服务 器 的 文件 系统 访问 。 
disk free_space0 函 数 获取 一 个 目录 的 可 用 空间 ， 语 法 如 下 : 


ER 
参数 directory 用 来 指定 文件 系统 或 磁盘 分 


| 说 明 : 本 函数 返回 的 是 目录 所 在 磁盘 分 区 的 总 大 小 ， 国 此 以 同一 个 磁盘 分 区 的 不 同 目录 作为 参数 所 得 到 的 
结果 完全 相同 。 


图 设计 过 程 

(1) 创建 index.php 文件 。 

(2) 添加 表单 ， 设 置 文本 框 、 提 交 按 钮 ， 使 用 POST 方法 将 数据 提交 到 本 页 。 

(3) 通过 $_ POST 方法 获取 表单 提交 的 目录 路 径 ， 首 先 ， 判 断 获 取 的 目录 是 否 合理 。 然 后 ， 通 过 iconv(0) 函 
数 对 获取 的 字符 串 进行 编码 转换 。 接 着 ， 对 获取 的 字符 串 进行 截取 ， 获 取 该 目录 所 在 的 磁盘 分 区 ， 并 应 用 
disk total space0 函 数 获 取 磁 盘 分 区 的 大 小 。 最 后 ， 应 用 opendir0 函 数 和 readdir0 函 数 读 取 提交 目录 下 的 内 容 。 

index.php 文件 的 关键 代码 如 下 : 


<?php 
if($_POST [file name'] !="" &&is file($ POST[file name]) 一 false{ 


ml 


$file_name = iconv ( "utf-8", "gb2312", $_POST ['file_name'] ); // 编 码 格式 转换 
if (file_exists ( $file name )) { // 判 断 目录 是 否 存在 
Slen = strripos ( $file_name, ":" ); // 截 取 字 符 串 
$dir = substr ( $file_name, 0, $len + 1 ); // 获 取 提 交 目 录 所 在 磁盘 
Sfilesize_z=disk_total_space ( $dir ); 1/ 获取 目录 总 大 小 
Sfilesize_z=number_format($filesize_z/(1024*1024*1024).2,".",""); /数字 的 格式 化 
Sfilesize_s=disk_free_space ( $dir ); // 获 取 磁 盘 剩 余 空间 
Sfilesize_s=number_format($filesize : ol 10240 2 // 字 节 的 格式 化 
echo "本 地 磁盘 〈". $dir .") 总 大 小 :" . $filesize z ." GB &nbsp; 可 用 空间 : ".$filesize_s." GB <br><br>"; 
echo $_POST ['file_ name'] ." 目录 下 的 内 容 : ". "<br>"; 
$i=0: 
Slist = opendir ( $file_name ): /打开 目录 
while ( S$read_list =readdir ( $list ) ) { // 读 取 目 录 
Si++; 
echo " $i: " .iconv ( "gb2312", "utf-8", $read list ) ." <br> "; // 输 出 目录 中 的 内 容 
} 
closedir ( $list ); // 关 闭 目 录 


}else{ 
echo "<script>alert(' 目 录 不 存在 ! ");</script>"; 


1 
j else{ 
echo "<script>alert(' 请 输入 正确 的 目录 路 径 ! ");</script>"; 


?> 


国 秘笈 心 法 


心 法 领悟 252: strriposO 函 数 判断 指定 字符 串 在 另 一 字符 串 中 最 后 出 现 的 位 置 。 
通过 strriposO) 函 数 可 以 获取 到 指定 字符 串 A 在 另 一 字符 串 B 中 最 后 出 现 的 位 置 ， 其 返回 值 为 int 型 ， 根 据 
这 个 返回 值 就 可 以 对 字符 串 B 以 字符 串 A 为 分 隔 点 进行 截取 ， 在 执行 截取 的 操作 时 需要 应 用 到 substr0 函 数 。 
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力 实例 说 明 


在 网 站 的 后 台 管理 系统 中 ， 经 常 需要 对 网 站 服务 器 中 的 文件 进行 管理 和 维护 ， 有 时 需要 添加 一 个 文件 夹 或 
删除 某 个 文件 夹 或 者 文件 ， 为 了 更 有 效 地 查看 这 些 文件 或 者 文件 夹 ， 最 好 的 方法 就 是 创建 一 个 文件 查询 系统 ， 
通过 它 可 以 查看 到 指定 文件 夹 下 的 所 有 文件 。 运 行 本 实例 ， 在 文本 框 中 输入 一 个 指定 的 文件 夹 ， 单 击 “ 提 交 ” 
按钮 ， 如 果 该 文件 夹 存 在 ， 就 可 以 显示 出 该 文件 夹 包括 的 所 有 文件 ， 运 行 结果 如 图 4.34 所 示 。 


,A 请 的 个 人 博客 


E 
目录 位 置 : 局 Wanpp\htdocsWR\O5\010 提交 


1 
3: images 
4: index. php 

Copyright © 1999-2010 吉林 省 明日 科技 有 限 公司 


图 4.34 遍历 指定 目录 下 的 所 有 文件 


力 关键 技术 


本 实例 实现 的 关键 是 目录 和 文件 处 理 函 数 的 应 用 , 包括 fle_existsO、is_dir0、opendir0、readdir0 和 closedir0 
函数 。 
(1) file_existsO 函 数 检查 文件 或 目录 是 否 存在 ， 语 法 如 下 : 


bool file_exists(string filename) 
如 果 由 filename 指定 的 文件 或 目录 存在 则 返回 TRUE， 否 则 返回 FALSE。 


(2) is_dir0) 函 数 判断 给 定 的 文件 名 是 否 为 一 个 目录 。 

bool is_dir(string filename) 

如 果 文 件 名 存在 并 且 为 目录 则 返回 TRUE。 如 果 filename 是 一 个 相对 路 径 ， 则 按照 当前 工作 目录 检查 其 相 
对 路 径 。 


< 注意 : is_dir0 函 数 的 结果 会 被 缓存 ; is_dir0 函 数 不 能 作用 于 远程 文件 ， 被 检查 的 文件 必须 通过 服务 器 的 
文件 系统 访问 。 
(3) opendir0 函 数 打开 目录 句柄 ， 语 法 如 下 : 
resource opendir ( string path) 
该 函数 返回 一 个 目录 句柄 ， 可 以 在 closedir0 和 readdir0 函 数 之 前 调用 。 如 果 path 不 是 一 个 合法 的 目录 或 者 
因为 权限 限制 或 文件 系统 错误 而 不 能 打开 目录 ，opendir0 函 数 返 回 FALSE 并 产生 一 个 错误 信息 。 
(4) readdir0 函 数 从 目录 句柄 中 读 取 条 目 ， 语 法 如 下 : 


string readdir( resource dir handle) 
该 函数 返回 目录 中 下 一 个 文件 的 文件 名 。 文 件 名 以 在 文件 系统 中 的 排序 返回 。 
(5) closedir0 函 数 关 闭 目录 句柄 ， 语 法 如 下 : 


string closedir( resource dir handle) 


本 函数 关闭 由 dir_handle 指定 的 目录 流 ， 目 录 流 必须 被 opendir0 函 数 打开 过 。 
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图 设计 过 程 
(1) 创建 index.php 文件 。 添 加 一 个 表单 ， 定 义 表单 元 素 ， 通 过 POST 方法 提交 目录 的 路 径 。 


(2) 在 index.php 文件 中 ， 判 断 提 交 的 目录 路 径 是 否 为 空 ， 如 果 不 为 空 ， 则 打开 目录 ， 读 取 目 录 中 的 文件 ， 
并 输出 读 取 到 的 文件 ， 关 闭 目 录 ; 否则 ， 输 出 目录 不 存在 ， 其 关键 代码 如 下 : 


<?php 
这 Ifile_exists ( $look_file ){ // 检 测 指定 的 目录 是 否 存在 
print $look_file." 目 录 不 存在 1" ; 
Jelse{ 
$i=0; 
if(is_dir ( $look_file ){ // 检 测 是 否 为 合法 目录 
if ($list= opendir ( $look_file ){ /打开 目录 
while (Sread list = readdir( $list )){ // 读 取 目 录 
Sitt; 
echo " $i: "iconv("gb2312","utf-8",$read list)." <br> " ; /| 输出 目录 中 的 内 容 
1 
} 
closedir ( $list ) ; // 关 闭 目 录 
} 
> 
图 秘笈 心 法 


心 法 领悟 253: 指定 目录 下 文件 的 读 取 、 操 作 。 


本 实例 只 是 可 以 浏览 到 指定 目录 下 包含 的 文件 , 不 可 以 对 文件 进行 操作 ， 有 关 如 何 操作 指定 目录 下 的 文件 ， 
将 在 后 面 的 实例 中 进行 讲解 。 


ee 


ee 


实例 254 趣味 指数 : 走 相 从 
图 实例 说 明 


通过 对 网 站 目录 的 遍历 ， 能 够 更 快 地 了 解 网 站 的 结构 和 网 站 文件 的 存储 位 置 ， 通 过 对 文件 内 容 的 遍历 ， 能 
够 掌握 网 站 中 每 个 文件 的 作用 ， 同 时 也 便于 对 目录 和 文件 的 管理 。 本 实例 将 介绍 如 何 实现 目录 和 文件 的 遍历 以 
及 删除 。 运 行 本 实例 ， 效 果 如 图 4.35 所 示 。 


图 4.35 人 遍历、 操作 指定 目录 下 的 所 有 文件 


PHP 开发 实例 大 全 (基础 卷 ) 


力 关键 技术 


遍历 、 操 作 指定 目录 下 的 所 有 文件 的 关键 是 目录 、 文 件 处 理 函 数 和 字符 串 处 理 函 数 的 综合 运用 。 
关键 的 目录 处 理 函数 如 下 : 
(1) chdir0 函 数 改 变 当前 目录 ， 语 法 如 下 : 
bool chdir(string directory) 
参数 directory 用 于 指定 更 改 后 目录 的 位 置 。 如 果 操作 成 功 则 返回 TRUE， 否 则 返回 FALSE。 
(2) getcwdO 函 数 获 取 当 前 工作 的 目录 ， 语 法 如 下 : 
string getcwd( void); 
(3) rmdir0 函 数 删 除 目录 ， 语 法 如 下 : 
bool rmdir ( string dimame ) 
尝试 删除 参数 dimame 所 指定 的 目录 。 该 目录 必须 是 空 的 而 且 要 有 相应 的 权限 。 如 果 成 功 则 返回 TRUE, 否 
则 返回 FALSE。 
在 对 文件 进行 操作 时 ， 主 要 应 用 到 如 下 几 个 函数 : 
(1) fopen0) 函 数 和 readfile0 函 数 已 经 在 实例 232 和 实例 230 中 介绍 过 ， 这 里 不 再 闭 述 。 
(2) fgets0 函 数 从 文件 指针 中 读 取 一 行 数据 ， 语 法 如 下 : 
string fgets( int handle [, int length] ) 
从 handle 指定 文件 中 读 取 一 行 并 返回 长 度 最 大 值 为 length-1 个 字 节 的 字符 串 。 
(3) felose0 函 数 关 闭 文件 ， 语 法 如 下 : 


bool felose ( resource handle ); 
将 参数 handle 指向 的 文件 关闭 ， 若 成 功 返 回 TRUE， 否 则 返回 FALSE。 
(4) filectime() 函 数 返回 指定 文件 的 索引 节点 修改 时 间 ， 语 法 如 下 : 
int filectime(string filename): 
返回 文件 上 次 索引 节点 被 修改 的 时 间 ， 如 果 出 错 则 返回 FALSE。 时 间 以 UNIX 时 间 惟 的 方式 返回 。 
(5) filemtime() 函 数 返回 指定 文件 flename 的 最 后 修改 时 间 ， 语 法 如 下 : 
int filemtime(string filename); 
返回 文件 上 次 被 修改 的 时 间 ， 失 败 则 返回 FALSE。 时 间 以 UNIX 时 间 截 的 方式 返 
(6) unlink0 函 数 删除 文件 ， 语 法 如 下 : 
bool unlink ( string filename ) 
删除 由 字符 串 fename 指定 的 文件 。 成 功 则 返回 TRUE， 否 则 返回 FALSE。 
在 完成 对 目录 和 文件 的 遍历 以 及 删除 过 程 中 ， 应 用 到 下 面 几 个 字符 串 函 数 : 
(1) substr0 函 数 从 指定 的 字符 串 中 按照 指定 的 位 置 截 取 一 定 长 度 的 字符 ， 语 法 如 下 : 


string substr(string str,int start,int length) 


substr() 函 数 的 参数 说 明 如 表 4.3 所 示 。 
表 4.3 substr() 函 数 的 参数 说 明 


回 


参 。 数 说 明 
str | 指定 字符 串 对 象 

start | ”指定 开始 截取 字符 串 的 位 置 。 如 果 参数 start 为 负数 ， 则 从 字符 串 的 末尾 开始 截取 

len 可 选 参数 ， 指 定 截取 字符 的 个 数 ， 如 果 length 为 负数 ， 则 表示 取 到 倒数 第 length 个 字符 


上 说 明 : substr() 函 数 中 参数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 串 中 的 第 1 个 字符 表示 为 0。 


(2) strpos0 函 数 寻 找 字 符 串 haystack 中 的 字符 needle 最 后 出 现 的 位 置 ， 语 法 如 下 : 
int stmpos(string haystack. char needle) 
参数 haystack 为 寻找 的 范围 ;参数 needle 为 寻找 的 字符 ， 其 中 needle 只 能 是 一 个 字符 ， 汉 字 不 可 以 。 如 果 
找 不 到 指定 的 字符 ， 则 返回 FALSE。 
(3) strtoupper0 函 数 将 字符 串 str 全 部 转换 为 大 写字 符 串 ， 语 法 如 下 : 
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string strtoupper(string str); 
(4) htmlentitiesO 函 数 ， 将 所 有 string 的 字符 都 转换 成 HTML 的 特殊 字 集 字符 串 ， 语 法 如 下 : 
string htmlentities(string string); 


图 设计 过 程 


(1) 创建 index.php 文件 。 应 用 目录 、 文 件 处 理 函 数 和 字符 串 处 理 函 数 完成 对 指定 目录 下 文件 的 读 取 操作 ， 
并 设置 查看 文件 内 容 的 超 链 接 和 删除 指定 文件 的 超 链 接 。 在 设置 超 链接 的 参数 时 ， 应 用 urlencode0 函 数 对 字符 
串 进 行 编 码 ， 其 完整 代码 请 参考 本 书 光 盘 。 


(2) 创建 look filephp 文件 ， 完 成 对 指定 文件 内 容 的 读 取 操作 ， 其 关键 代码 如 下 : 
<?php 


S$catalog = iconv ( "utf-8", "gb2312", urldecode ($_GET [catalog] ) ); // 获 取 文件 的 信息 ， 设 置 编码 
Sfilename = iconv ( "utf-8", "gb2312", urldecode ( $_GET [filename] ) ); /获取 文件 的 信息 ， 设 置 编码 
$type=iconv ( "utf-8", "gb2312", urldecode ( $_GET [type] ) ); /获取 文件 的 信息 ， 设 置 编码 
Stypes = strtoupper ( $type ); // 完 成 字符 串 的 大 小 写 转换 
if($types =— "PHP") { // 显 示 PHP 文件 的 内 容 
Sarr = file ( $catalog . "\". $filename ); // 读 取 文件 
foreach ( $arr as $value ) { // 循 环 输出 文件 内 容 

Svalue = htmlentities ( $value, ENT_COMPAT, "UTF-8" ); /特殊 字符 的 转换 

echo $value . "<br>"; // 输 出 内 容 
ya 
Sfp = fopen ( $catalog . "\\" . $filename, "r" ); 1/ 显示 .txt 文 件 的 内 容 
while ( $line = fgets ( $fp ) ) { 

Sline = htmlentities ( $line, ENT_COMPAT, "GB2312" ); /特殊 字符 的 转换 

echo iconv ( "gb2312", "utf-8", $line ); /| 输出 文件 内 容 
ee . 
} 


> 

(3) 创建 delete php 文件 ， 完 成 对 指定 文件 的 删除 操作 ， 代 码 请 参考 本 书 光 盘 。 
国 秘笈 心 法 

心 法 领悟 254: 对 URL 字符 串 进行 编码 的 重要 性 。 

在 通过 URL 传递 字符 串 参数 时 ， 尽 量 应 用 urlencode0 函 数 对 传递 的 参数 值 进 行 编 码 ， 这 样 不 但 可 以 保证 传 
递 参 数值 的 安全 ， 而 且 可 以 防止 传递 的 参数 值 出 现 乱 码 。 例 如 ， 本 实例 中 在 执行 指定 目录 、 文 件 的 删除 操作 时 ， 


在 执行 成 功 跳 转 到 上 级 页 面 时 ， 如 果 不 对 URL 传递 的 字符 串 参 数值 进行 编码 ， 那 么 就 不 能 够 完成 跳 转 的 操作 ， 
会 弹出 一 个 错误 提示 。 
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第 章 


会 话 应 用 


WH COOKIE 应 用 
WH SESSION 应 用 


第 5 章 会 话 应 用 
5.1 COOKIE 应 用 


在 Web 技术 发 展 的 历史 上 ，COOKIE 技术 的 出 现 是 一 个 重大 的 变革 。 最 先是 Netscape 公司 在 其 Netscape 
Navigator 浏览 器 中 引入 了 COOKIE 技术 ， 从 那 时 起 ，World Wide Web 协会 就 开始 支持 COOKIE 标准 。 以 后 又 
经 过 微软 公司 的 大 力 推 广 ， 即 在 微软 公司 的 Intemet Explorer 浏览 器 中 完全 支持 COOKIE 技术 ， 到 现在 ， 绝 大 
多 数 浏览 器 都 支持 COOKIE 技术 ， 或 者 至 少 兼 容 COOKIE 技术 的 使 用 。 


实例 255 趣味 指数 : 全 让 容 二 
实例 说 明 


COOKIE 是 在 HITP 协议 下 ， 将 服务 器 传递 给 浏览 器 的 少量 数据 保存 到 用 户 浏览 器 的 一 种 方式 。 通 过 这 种 
方式 ， 即 使 在 浏览 器 被 关闭 和 连接 中 断 的 情况 下 ， 用 户 仍然 可 以 维护 状态 数据 。 本 实例 在 创建 和 读 取 COOKIE 
的 同时 ， 设 置 COOKIE 的 生命 周期 ， 实 现 控制 登录 用 户 的 过 期 时 间 。 运 行 结果 如 图 5.1 所 示 。 

而。 线 me mm 


欢迎 mr 光临 ! 


5.1 控制 登录 用 户 的 过 期 时 间 


图 关键 技术 


(1) setcookie() 函 数 设置 COOKIE， 其 代码 如 下 : 
bool seteookie (string name [, string vatoe [, int expire [, string paih (, stiing domain [int seeure]I]D); 


该 函数 的 参数 说 明 如 表 5.1 所 示 。 


表 5.1 setcookie() 函 数 的 参数 说 明 


举例 
可 以 通过 $ COOKIE['cookiename] 调 用 变量 名 为 
weil | knitinte cookiename 的 COOKIE 


Bh 该 值 保 存在 客户 端 ， 不 能 用 来 保存 可 以 通过 $ COOKIE[values "| 获取 名 为 values 的 什 
COOKIE 的 过 期 时 间 , expire 是 标准 的 UNIX 时 间 标 记 , | 如 果 不 设置 COOKIE 的 过 期 时 间 , 那么 COOKIE 将 永远 
可 以 用 time0 函 数 或 mktime0 函 数 获取 ， 单 位 为 秒 有 效 ， 除 非 手 动 将 其 删除 

如 果 该 参数 设置 为 “/”， 则 它 在 整个 domain 内 有 效 ， 如 
果 设 置 为 “/5.1”, 它 在 domain 下 的 /5.1 目录 及 子 目录 内 
有 效 。 默 认 是 当前 目录 

如 果 要 使 COOKIE 在 mrbccd.cn 域名 下 的 所 有 子 域 都 有 
效 ， 应 该 设置 为 mrbccd.cn 

如 果 值 为 1， 则 COOKIE 只 能 在 HTTPS 连接 上 有 效 ; 如 
果 值 为 默认 值 0， 则 在 HTTP 和 HTTPS 连接 上 均 有 效 


path ”|COOKIE 在 服务 器 端的 有 效 路 径 


domain |COOKIE 有 效 的 域名 


secure “| 指明 COOKIE 是 否 仅 通过 安全 的 HITPS， 值 为 0 或 1 
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(2) $_COOKIE: 经 由 HTTP Cookies 方法 提交 至 脚本 的 变量 ， 用 于 获取 COOKIE 变量 的 值 。 


力 设计 过 程 
(1) 创建 index php 文件 ， 编 写 用 户 登录 页 面 ， 将 用 户 登 录 信息 提交 到 index_ok.php 文件 。 
(2) 创建 index_ok php 文件 ， 获 取 表单 提交 的 用 户 登录 信息 ， 并 且 判 断 登 录 的 用 户 名 和 密码 是 否 正确 ， 如 


果 正 确 ， 则 将 用 户 名 和 密码 赋 给 指定 的 COOKIE 变量 ， 并 设置 COOKIE 的 过 期 时 间 ， 跳 转 到 cookie.php 页 面 ; 
否则 ， 直 接 给 出 提示 信息 ， 并 重新 跳 转 到 登录 页 ， 其 关键 代码 如 下 : 


<?php 

这 $_POST[user] 一 "mr && $ POST[pass] 一 "mrsoft){ // 判 断 用 户 名 和 密码 是 否 正确 
setCookie("user",$_POST['user],time(+60)or die(" 禁 止 cookie"); // 创 建 COOKIE 
setCookie("pass",$_POST['pass']:time()+60)or die(" 禁 止 cookie"); /| 创建 COOKIE 


echo "<script>alert( 登 录 成 功 ! "); window.location href='cookie.php';</script>"; 

jelsef 

echo "<seript>alert( 用 户 名 或 者 密码 不 正确 1 ): window location href="index -php':</seript>"; 
} 


?> 
(3) 创建 cookie .php 文件 ， 判 断 COOKIE 变量 的 值 是 否 存在 ， 如 果 存 在 则 输出 本 页 内 容 ， 否 则 ， 给 出 提 
示 信 息 并 跳 转 到 登录 页 面 ， 其 关键 代码 如 下 : 
Re 
echo "欢迎 光临 !"; 
) echo "<script>alert(COOKIE 已 经 过 期 ， 请 重新 登录 ); window.location href="'index.php';</script>"; 
} 


?> 
国 秘笈 心 法 
心 法 领悟 255: 会 话 COOKIE。 


如 果 不 设 置 COOKIE 的 时 间 ， 就 表示 其 生命 周期 为 浏览 器 会 话 的 时 间 ， 只 要 关闭 正 浏览 器 ，COOKIE 就 
会 自动 消失 ， 这 种 COOKIE 被 称 为 会 话 COOKIE， 一 般 不 保存 在 硬盘 上 ， 而 是 保存 在 内 存 中 。 


高 级 | 
实例 | 
i | | 
图 实例 说 明 

所 谓 自动 登录 ， 即 用 户 第 一 次 成 功 登 录 网 站 后 ， 在 一 段 时 间 内 再 次 登录 该 网 
站 时 不 再 需要 填写 用 户 名 和 密码 ， 而 是 可 以 直接 进入 。 

运行 本 实例 ， 如 果 是 第 一 次 登录 ， 则 需要 填写 用 户 名 和 密码 才能 够 登录 。 如 
果 是 再 次 登录 ， 那 么 就 不 需要 输入 用 户 名 和 密码 ， 因 为 8_COOKIE 会 从 COOKIE 


中 读 取 这 些 信息 ， 用 户 直 接 单 击 登录 按钮 即 可 。 登 录 成 功 后 进入 main.php 页 面 ， 
运行 结果 如 图 5.2 所 示 。 


图 关键 技术 


本 功能 实现 的 关键 是 COOKIE 的 创建 、 过 期 时 间 的 设置 和 COOKIE 值 的 获取 。 其 中 创建 COOKIE 应 用 的 
是 setcookie0 函 数 ， 有 关 该 函数 的 应 用 、 过 期 时 间 的 设置 和 COOKIE 值 的 获取 请 参考 实例 255 中 的 关键 技术 ， 
这 里 不 再 袭 述 。 


渐 开 于 录 和 


图 5.2 进入 网 站 主页 
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图 设计 过 程 


(1) 创建 index.php 文件 ， 创 建 表单 ， 添 加 用 户 名 、 密 码 文本 框 和 保存 时 间 选 择 单 选 按钮 。 最 关键 的 是 编 
写 PHP 脚本 ， 通 过 $_COOKIE 获取 COOKIE 中 存储 的 用 户 名 和 密码 数据 ， 并 将 其 作为 用 户 名 和 密码 的 默认 值 ， 
其 关键 代码 如 下 : 


<form id="forml" name="forml" method="post" action="index ok.php"> 

<input id="lgname" name="name" valuc="<3php echo $ COOKIE['name']:?>" type="text" class="txt"/> 

<input id="lgpwd" name="pwd" value="<?php echo $ COOKIE['pwd']:2>" type="password" class="txt"/> 

<input name="times" type="radio" value="3600" checked="checked" />1 小 时 

<input type="radio" name="times" value="86400" />1 天 

<input type="image" name="imageFicld" sre="images/dL.gif" /> 

<input type="image" name="imageField2" onclick="form reset();return false;" sre="images/cz.gif" /> 

</form> 

(2) 创建 index_ok.php 文件 ， 通 过 $_POST 方法 获取 表单 中 提交 的 数据 ， 验 证 用 户 输入 的 用 户 名 和 密码 是 

否 正 确 。 如 果 正 确 ， 则 通过 setcookie0 函 数 创建 COOKIE， 存 储 用 户 名 和 和 密码， 并 根据 表单 提交 的 时 间 设 置 
COOKIE 的 过 期 时 间 ， 并 跳 转 到 main php 页 面 ， 如果 不 正确 ， 则 给 出 提示 信息 ， 并 跳 转 到 index.php 页 面 ， 其 


关键 代码 如 下 : 


<?php 
if(! empty ($_ POST [name] ) and ! empty($_ POST [pwd]){ // 判 断 用 户 名 和 密码 是 否 为 空 
mr" && $_POST [pwd] — "mrsoft") { 

,$_ POST [name],time 0 + $_POST [times] ); /设置 COOKIE 的 有 效 时 间 为 1 小 时 
setcookie ( "pwd",$ POST [pwd],time 0 + $_POST [imes'] ); /设置 COOKIE 的 有 效 时 间 为 1 小 时 
echo "<script>alert('succeed!");window.location .href="main.php':</seript>"; 

}else{ 
echo "<script>alert('false!');:window.location.href="index.php';</script>"; 


Yelse{ 
~ ccho "<seript>alert(NULL);window location href-"index php':<lscript>"s; 
} 


3) 创建 main.php 文件 ， 首 先 根据 8 COOKIE 获取 的 COOKIE 值 判断 用 户 是 否 具有 访问 权限 ， 如 果 有 则 
可 以 看 到 本 页 内 容 ， 和 否则 将 给 出 提示 信息 ， 跳 转 到 index.php 页 面 ， 其 关键 代码 如 下 : 


<2php 

if($_COOKIE[name]—""){ /根据 COOKIE 的 值 判断 浏览 者 是 否 具 有 访问 该 页 面 的 权限 
echo "<script>alert(' 您 不 具有 访问 该 页 面 的 权限 ! "); window.location href='index.php':</seript>": 
jelsef /如 果 正 确 ， 则 输出 主页 内 容 


?> 
<!-- 省 略 了 HTML 内 容 --> 
<2php 


中 
> 


国 秘笈 心 法 
心 法 领悟 236: COOKIE 的 优点 。 


在 使 用 COOKIE 时 ， 如 果 设 置 了 COOKIE 的 过 期 时 间 ， 浏 览 器 将 会 保存 COOKIE 数据 ， 即 使 用 户 重新 启 
动 计 算 机 ， 只 要 没有 过 期 ，COOKIE 数据 就 一 直 有 效 。 


ee 本 
力 实例 说 明 


现在 越 来 越 多 的 企业 、 个 人 喜欢 用 互联 网 来 进行 沟通 和 交流 ， 诸 如 留言 板 、 聊 天 室 、 论 坛 和 博客 等 交流 和 
展示 自己 的 方式 层出不穷 ， 而 且 一 个 企业 或 者 个 人 可 能 拥有 上 述 多 种 交流 方式 。 因 为 每 种 交流 方式 都 具有 自己 
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的 身份 验证 机 制 ， 这 样 势必 造成 如 果 某 位 用 户 要 以 会 员 的 身份 访问 网 站 ， 需 要 在 每 个 网 站 上 注册 ， 通 过 身份 验 
证 后 ， 才 能 以 会 员 的 身份 访问 网 站 。 即 使 用 户 以 同样 的 用 户 名 与 密码 在 每 个 网 站 上 注册 ， 这 样 虽然 可 以 避免 忘 
记 或 混淆 各 用 户 名 和 密码 ， 但 是 如 果 用 户 在 某 一 时 间 段 内 需 访问 网 站 的 多 个 页 面 或 者 在 不 同 网 站 间 跳 转 ， 仍 然 
需要 登录 后 才能 以 会 员 的 身份 访问 网 站 的 话 ， 不 仅 给 用 户 带 来 了 不 便 ， 而 且 也 浪费 了 服务 器 的 空间 。 

如 果 所 有 的 网 站 能 够 实现 单 点 登录 ， 不 仅 在 用 户 体验 方面 有 所 提高 ， 而 且 真正 体现 了 集团 多 个 网 站 的 “ 兄 
弟 ” 性 。 通 过 这 种 有 机 结合 ， 不 但 便于 对 网 站 进行 管理 ， 而 且 能 更 好 地 体现 公司 大 平台 、 大 渠道 的 理念 。 同 时 
这 样 做 也 利于 网 站 的 相互 促进 与 相互 宣传 。 

运行 本 实例 ， 如 果 是 第 一 次 登录 ， 那 么 将 进入 登录 页 面 ， 登 录 成 功 后 进入 博客 主页 ， 如 图 5.3 所 示 ; 单 击 
博客 主页 中 的 “我 的 论坛 ”， 将 以 此 用 户 身份 直接 进入 论坛 系统 主页 ， 如 图 5.4 所 示 ; 同样 ， 单 击 论坛 系统 主 
页 中 的 “博客 ”可 以 跳 转 到 博客 主页 面 。 


区 从 .时 这 的 个 


当前 用 户 : er EP 


出 自 《 提 窗 小 记 》 里 面 这 衬 一 旺 计 联 : 宠 慰 不 个 ,看 许 彰 花 开 共和 ;去 六 无 间 ， 训 天 空 去 者 去 好 。 这 生活 的 意 时 是 说， 为 人 做事 能 视 宅 奈 各 
花 开 本 入 服 平 过 ， 才 讲 不 售 ; 视 职位 和 名 如 元 基 去 他 能 至 和 ， 才 宰 无 韶 。 现在 的 人 二 多 营 得 活性 很 时 ， 不 二 重负 ， 大 家 很 是 纳 问 ， 为 什么 村 会 在 
不 斯 进 抄 ， 而 人 印 负 而 和 更 重 ， 精神 址 发 宝 度 ， 思 起 呈 宪 踊 。 的 区， 社会 在 不 断 机 坦 ， 也 更 加 文明 了 ， 名 而 文明 社会 的 一 个 直上 到 是 过 成 人 与 
目 关 的 有 区分 高 ， 人 闫 欠 届 性 自 共 方 代价， 其 结果 便 是 陋 于 世 作 的 沈 译 大 无 法 目 技 ,这 区 于 外 在 的 礼法 与 相 坎 而 不知 什么 是 让 正 的 羌 。 全 铁 的 
十 、 权 力 斩 骨 洱 、 下 海 的 页 学 让 人 歼 必 渴 虞 ， 是 非 、 成 取 、 袜 大 引 人 或 诗 、 台 志 、 职 乐 、 或 汤 、 开 忆 、 到 中， 一 所 记 准 以 详 砚 ， 一 旦 所 起 准 以 
碟 功 ， 一旦 蒂 户 区 实 成 了 洒 影 ， 台 会 类 芒 、 天 总 至 尖 刻 。 兴 膏 是 一 种 心理 类 秽 ， 白 站 要 生 夫 东区 精神 现 象 未 调节 ; 失意 是 一 种 心理 顺 逢 ， 是 失 
基 的 情 溢 化 与 深 齐 化 ; 失 志 则 是 一 种 心理 失败 ， 是 玫 让 的 普度 ， 是 失范、 失意 的 终 季 表现。 而 要 更 有 这 种 失落 、 失 意 、 失 志 甩 要 充 怀 二 你、 去 
周 无 意 。 一 恒 对 秩 ， 容 字 效 语 ,部 这 $ 简 出 了 人 生 对 事 对 侯 、 对 名 对 利 应 有 有关 总 度 : 衬 之 下 柯 ， 失 之 干 惰 、 完 导 不 个 、 去 贸 无 意 。 这样 才 可 能 心 
境 平和 ， 深 治 自 然 。 一 个 看 许 划 三 字 , 太 有 服 浊 小 次 成 一 纺 ， 管 好 春 夏 与 秋冬 之 意 ， 而 望 天 上 三 字 则 又 显示 了 训 大 眼光 ,不 与 他 人 一 舰 见识 的 六 
过 铺 钰 : 一 句 寺 着 天 好 更 有 大 二 去 能 居家 介 的 并 高 请 界 。 与 范 仲 沪 闪 丰 | 物 哥 、 不 外 己 于 实在 是 异 由 同 工 , 更 取 有 部 否 人 物 的 了 汉沽 。 完 导 不 
昼 ， 共 六 无 间 襄 到 天 窑 易 ， 抽 所 到 十 分 于 只 


Ee 
图 5.3 进入 博客 主页 面 
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图 5.4 进入 论坛 系统 主页 


力 关键 技术 


本 实例 开发 一 个 博客 网 站 和 一 个 论坛 网 站 ， 通 过 COOKIE 实现 单 击 登录 的 功能 ， 即 无 论 在 博客 或 者 论坛 网 
站 中 ， 只 要 登录 后 此 用 户 名 在 一 定时 间 内 ， 在 这 两 个 网 站 中 是 通用 的 。 

关键 就 是 对 COOKIE 值 的 判断 , 如果 COOKIE 的 值 存在 并 且 与 数据 库 中 存储 的 值 相同 , 那么 就 可 以 实现 不 
同系 统 之 间 的 跳 转 ， 否 则 就 必须 先 登录 ， 才 可 以 访问 系统 中 的 内 容 ， 其 关键 代码 如 下 : 


第 5 章 会 话 应 用 


<php 
include_once 'conn/conn php'; // 执 行 连接 数据 库 的 操作 
if($_COOKIE[name]!="" and $ COOKIE[id]!="){ 

$sql = "sclect* from tb_ login where name =".$_COOKIE[name]." and login id=".$ COOKIE[id].™": 


Snum = $conne->getRowsNum($sq]); // 返 回 查询 结果 
Sconne->close_rst(); // 关 闭 数据 库 
if($num != 0 or $num != "){ // 如 果 在 数据 表 存在 该 记录 ， 则 直接 跳 转 到 登录 页 面 
header("Location: default.php"); 
jelse{ /否则 输出 登录 页 面 的 内 容 
> 
<!-- 省 略 了 部 分 代码 -> 
<php 


jelsef 

/清除 数据 库 中 1 小 时 以 前 存储 的 用 户 登 录 数据 〈 即 SESSION 过 期 以 后 的 数据 ) 
$datetimes=mktime0-3600: /获取 1 小 时 前 的 时 间 惟 
$sqls="delete from tb_login where datetime<".$datetimes.™"; // 执 行 删除 操作 

Snums = $conne->uidRst($sqls); // 返 回 查 询 结 果 


> 
<!-- 省 略 了 部 分 代码 --> 
<2php } ?> 


图 设计 过 程 


这 里 以 博客 网 站 为 例 ， 讲 解 具体 的 操作 步骤 : 

(1) 创建 index.php 页 面 ， 添 加 用 户 登 录 的 表单 ， 将 登录 信息 提交 到 index_ok.php 页 面 中 。 在 index.php 页 
面 中 首先 连接 数据 库 ， 然 后 判断 COOKIE 的 值 是 否 为 空 ， 如 果 值 不 为 空 ， 并 且 在 指定 的 数据 表 中 存在 该 记录 ， 
那么 将 直接 进入 网 站 的 主页 ， 不 必 进 行 登录 操作 ; 如 果 值 为 空 ， 则 输出 网 站 登录 页 面 ， 并 且 删 除 指定 数据 表 中 
已 经 过 期 的 用 户 登 录 信 息 ， 其 代码 请 参考 关键 技术 中 的 内 容 。 

(2) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 登录 信息 ， 完 成 登录 操作 。 单 击 登录 的 第 一 个 关键 点 : 将 
登录 成 功 的 用 户 名 和 SESSION ID 值 保存 到 COOKIE 中 ,设置 COOKIE 的 过 期 时 间 为 1 小 时 ， 有 效 范 围 是 服务 
器 的 根 目录 ; 单 点 登录 的 第 二 个 关键 点 : 将 登录 的 用 户 名 和 SESSION ID 值 存储 到 一 个 数据 表 中 。 此 COOKIE 
值 和 数据 表 中 的 数据 是 验证 当前 用 户 是 否 具有 单 点 登录 权限 的 唯一 依据 ， 代 码 如 下 : 


<php 

session_start(); 

include_once 'conn/conn.php'; /执行 连接 数据 库 的 操作 
$name = addslashes($_POST['name']): /获取 用 户 名 


$pwd=$_POST[pwd]: /获取 密码 
if(!empty($name) and !empty($pwd))f 
$sql = "select * from tb_member where name =".$name." and password = ".Spwd: 


Snum = $conne->getRowsNum($sql); /返回 查询 结果 

$conne->close_ rst(0; /释放 查询 结果 

if($num 一 0 or $num — "){ // 如 果 不 正确 
echo "<script>alert( 用 户 名 和 密码 不 正确 ! ); window .location href='index.php':</script>"; 

Jelse{ // 如 果 正 确 ， 则 将 登录 用 户 名 数据 存储 到 COOKIE 中 
S$session_id=session_idO; /获取 SESSION ID 
setcookie("name", $name, time()+3600, "/"): /创建 COOKIE 


setcookie("id", mds($session_id), time()+3600, "/"); /创建 COOKIE 
$sqls="insert into tb_login(name.login_id.datetime)values(".$name.™,".md$($session_id).™,".mktime().")"; $nums = $conne->uidRst($sqls); 
/返回 查询 结果 
echo "<script>alert(' 登 录 成 功 ! '); window.location href-'defaultphp':</scripP>": 
} 


> 
(3) 创建 default.php 网 站 主页 面 。 其 关键 就 是 根据 COOKIE 值 和 指定 数据 表 中 存储 的 数据 判断 当前 用 户 
是 否 具有 访问 主页 的 权限 ， 如 果 有 则 输出 网 站 主页 的 内 容 ， 否 则 将 跳 转 到 登录 页 面 ， 代 码 如 下 : 


<?php 
if($_COOKIE[name]!="" and $_COOKIE[id]!=""){ 
include_once 'conn/conn.php'; /执行 连接 数据 库 的 操作 
$sql = "select + from tb_login where name =".$_COOKIE[name]." and login 这 ="S_COOKIE[id]."": 
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Snum = $conne->getRowsNum($sql); // 返 回 查询 结果 
$conne->close_rst(); /关闭 数据 库 
这 $num — 0 or Snum — "){ 
header("Location: index.php"); 
yelse{ 
> 
/省 略 了 主页 面 代码 
<?php 
yelse{ 


header("Location: index.php"); 
} 


?> 


(4) 在 conn 文件 夹 下 创建 conn.php 文件 ， 实 现 连接 数据 库 的 操作 。 
图 秘笈 心 法 
心 法 领悟 257: 单 击 登录 的 注意 事项 。 


如 果 当 前 用 户 手动 清除 了 客户 端 COOKIE 的 信息 ， 那 么 本 实例 的 功能 就 会 失效 ， 需 要 重新 登录 ; 如果 当 前 
用 户 的 客户 端 禁止 了 COOKIE 功能 的 使 用 ， 那 么 本 实例 就 不 能 实现 单 击 登录 的 效果 。 


Pi 
高 级 | 
ao oo 


图 实例 说 明 


所 谓 用 户 在 线 时间 是 指 从 用 户 登 录 到 页 面 开始 ， 到 关闭 浏览 器 为 止 的 时 间 ， 而 COOKIE 的 生命 周期 在 默认 
情况 下 关闭 浏览 器 时 自动 删除 ， 这 非常 符合 在 线 统计 时 间 的 特点 ， 是 很 多 服务 类 网 站 优先 选择 的 统计 手段 。 

本 实例 通过 创建 COOKIE， 保 存 用 户 登 录 到 页 面 的 时 间 戳 ， 在 用 户 单 击 退出 按钮 时 计算 用 户 在 线 时 间 。 运 
行 结果 如 图 5.5 所 示 。 


在 线 时 间 : 0001:43 秒 ! 
息 的 IP 地 址 :192.168.1.59 
您 的 机 器 名 称 ， pih 


ER 


图 5.5 统计 用 户 的 在 线 时 间 


力 关键 技术 


本 实例 的 关键 点 是 通过 创建 COOKIE 保存 用 户 登录 到 页 面 的 时 间 戳 ， 并 与 结束 时 间 戳 做 减法 运算 。 
用 户 登录 时 间 : 

S$str = time(): 

setcookie('times', $str); 

用 户 退 出 时 间 : 

Sstring = time()-$_COOKIE['times']; 

echo "在 线 时 间 : ".date("H:i:s",$string)" 秒 ! "."<br>"; 


图 设计 过 程 
(1) 沿用 实例 257 的 Forum 系统 ， 在 index php 文件 中 创建 COOKIE， 存 储 用 户 的 登录 时 间 截 ， 其 关键 代 
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码 如 下 : 
<?php 
include_once 'conn/conn .php': /执行 连接 数据 库 的 操作 
S$str = time(); 
setcookie('times', $str); 
if($_COOKIE[name]!="" and $ COOKIE[id]!="){ 
$sql = "select * from tb_login where name =".$_COOKIE[name]." and login id=".$ COOKIE[id]"": 


Snum = Seconne->getRowsNum($sqD: /返回 查询 结果 
Sconne->close_rst(); /关闭 数据 库 
这 Snum (= 0 or $num (= "){ 

eader("Location: default.php"): 
Jelse{ 


> 
(2) 创建 information.php 文件 ， 应 用 系统 的 当前 时 间 惟 减 去 COOKIE 中 存储 的 登录 时 间 戳 ， 即 获取 到 系 
统 在 线 时 间 的 时 间 戳 ， 并 通过 dateO 函 数 对 这 个 时 间 改 进行 格式 化 ， 输 出 用 户 的 在 线 时 间 ， 同 时 输出 登录 用 户 的 


卫 和 机 器 名 称 ， 其 关键 代码 如 下 : 
<?php 
$string = time()-$_COOKIE['times']; 
echo "在 线 时 间 : ".date("Hi:i:s",$string)." 秒 !"."<br>"; 
echo "您 的 他 地址 : ".getenv(REMOTE_ADDR”)."<br>"; 
echo "您 的 机 器 名 称 : ".gethostbyaddr(getenv(‘REMOTE_ADDR)): 
> 
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心 法 领悟 258: COOKIE 会 一 直 伴 随 网 站 中 的 每 个 请 求 ， 直 到 过 期 为 止 。 
浏览 器 创建 一 个 COOKIE 后 ， 对 于 每 一 个 针对 该 网 站 的 请 求 都 会 在 Header 中 带 有 这 个 COOKIE， 而 且 浏 
览 器 会 一 直 发 送 ， 直 到 COOKIE 过 期 为 止 。 不 过 ， 对 于 其 他 网 站 的 请 求 ，COOKIE 不 会 一 起 发 送 。 


RE 一 。 | 
2 趣味 指数 : 让 二 三 本 | 
国 实例 说 明 


默认 情况 下 ，COOKIE 的 生命 周期 是 以 关闭 浏览 器 为 基准 的 ， 也 就 是 说 如 果 用 户 不 关闭 浏览 器 并 且 没 有 对 
COOKIE 进行 设置 ， COOKIE 永远 也 不 会 过 期 失效 。 假 如 用 户 在 互联 网 发 布 的 网 站 有 成 百 上 千 的 用 户 浏览 ， 
并 且 在 线 浏览 用 户 数量 一 直 增加 ， 如 果 不 对 用 户 访问 网 站 的 时 间 进 行 限制 ， 结 果 只 能 是 服务 器 资源 耗 尽 ， 网 站 


瘫痪 。 
本 实例 通过 设置 COOKIE 限制 用 户 访问 网 站 的 时 间 ， 运 行 结果 如 图 5.6 和 图 5.7 所 示 。 
FANXING -ss A 
rm | er 
weenass am 2 Er aa ous ma wen ad am 
让 = 
| wees 您 访问 网 站 的 时 间 到 了 ! 
图 5.6 COOKIE 未 失效 ， 访 问 网 站 图 5.7 COOKIE 失效 
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图 关键 技术 


本 实例 的 关键 点 是 通过 setcookie0 函 数 创建 COOKIE 并 设置 COOKIE 的 有 效 时 间 。 然 后 通过 判断 COOKIE 


变量 是 否 存在 及 COOKIE 变量 的 值 是 否 为 空 来 控制 用 户 访问 网 站 的 时 间 ， 其 关键 代码 如 下 : 
<?php 


session_start(); // 初 始 化 SESSION 变量 
Ssession id=session id0; /获取 SESSION _ID 
setcookie("start",$session id,time()+10); // 定 义 COOKIE 变量 ， 设 置 COOKIE 的 有 效 时 间 是 10 秒 
?> 
图 设计 过 程 


(1) 创建 index.php 文件 。 首 先 初始 化 SESSION 变量 获取 SESSION_ ID， 然后 通过 setcookie0 函 数 创建 
COOKIE， 并 将 SESSION _ID 作为 COOKIE 值 ， 同 时 设置 COOKIE 的 有 效 时 间 为 10 秒 。 
(2) 最 后 ， 在 页 面 中 通过 判断 COOKIE 变量 的 值 是 否 为 空 来 限制 用 户 访问 网 站 的 时 间 ， 其 关键 代码 如 下 : 
hp 
tse cookfooal $_COOKIE['start]—$session id){ 
.省略 了 网 页 中 的 代码 
jdket 
echo "<hl style =color:red;> 您 访问 网 站 的 时 间 到 了 </h1>"; 
} 


2> 


国 秘笈 心 法 

心 法 领悟 259: 使 用 COOKIE 存在 隐患 。 

COOKIE 是 以 一 种 客户 端 明文 文件 的 方式 存储 的 ， 这 样 会 涉及 一 个 安全 问题 ， 所 以 在 使 用 COOKIE 保留 用 
户 资料 时 CGI 会 有 一 个 加 密 过 程 。 


实例 260 | 


趣味 指数 : 址 食 食 全 | 


力 实例 说 明 
COOKIE 是 用 来 解决 HTTP Web 协议 无 状态 的 问题 的 ， 可 以 作为 一 种 暂时 性 的 短信 息 存储 器 ， 存 储 变量 值 


或 者 属性 ， 其 最 主要 的 应 用 是 保存 客户 信息 ， 如 用 户 名 、 密 码 、 联 系 方式 、 家 庭 住 址 等 。 
本 实例 实现 用 户 注册 的 功能 ， 并 通过 COOKIE 获取 用 户 注册 的 用 户 名 、 密 码 ， 其 运行 结果 如 图 5.8 所 示 。 
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图 5.8 用 户 注册 时 客户 端 获取 的 COOKIE 数据 


第 5 章 会 话 应 用 


图 关键 技术 


本 实例 实现 简单 的 用 户 注 册 功 能 ， 其 关键 是 运用 setcookieO) 函 数 创 建 COOKIE 变量 ， 将 用 户 的 注册 信息 存 
储 到 客户 端 ， 客 户 端 COOKIE 的 数据 存储 于 如 图 5.9 所 示 的 文件 中 。 


C192.168.1.59/nr/05/006/0 
p89 9A E30 0925 85 7 N78 


图 5.9 客户 端 生成 的 COOKIE 文件 


通过 setcookie0 函 数 创 建 COOKIE， 存 储 用 户 名 和 密码 并 设置 密码 的 有 效 时 间 。 最 后 ， 通 过 自动 全 局 变量 
$_COOKIE 获取 并 输出 COOKIE 变量 中 存储 的 数据 。 


力 设计 过 程 
(1) 创建 index.php 文件 ， 添 加 表单 、 表 单元 素 ， 完 成 用 户 注册 页 面 的 设计 。 同 时 能 够 对 提交 的 用 户 名 进 
行 检 测 ， 对 验证 码 进行 刷新 操作 ， 其 关键 代码 如 下 : 


<form name="form1" method="post" action="index_ok.php"> 
<input name="name" type="text" value="<?php echo $ EE size="15"> 
<input name="check" type="submit" id="check" value=" 检 测 " /> 
<input name="pwd" type="password" size="15" value="<?php echo $COOKIE[pwd]:?>" /> 
<input name="ym" type="text" size="5"> 
<?php 


Sarray = array(1 =>"pic/1 jpg",2 一 "pic/2jpg"3 一 "pic/3jpg",4 =>"pic/4.jpg",5 一 "pic/5jpg， 
for($a = 0:$a < 4;5at+){ /执行 如 入 二， 获取 数组 中 的 图 片 数据 
Srand = rand(1,5)."&nbsp;"; // 获 取 随机 数据 
} 
S$rands = explode("&nbsp:"Srand); // 通 过 &nbsp 分 隔 字符 串 
Srande = implode($rands): // 读 取 数组 中 的 数据 ， 返 回 一 个 字符 串 
$_SESSION['ym']=$rande; // 将 字符 串 赋 给 SESSION 变量 
for($b=0:$b < 4:$b++){ 1/ 执行 for 循环 
echo "<img sre=pic/".$rands[$b]."jpg>"; // 输 出 验证 码 图 像 
国 
<a href='index.php> 刷 新 </a> 
<br><br> 


&nbsp;&nbsp:<input type="submit" name="sub" value=" 注 册 " /> 
&nbsp:&nbsp;<input type="reset" name="res" valuc=" 重 置 " /> 
</form> 
(2) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 完 成 用 户 注册 的 操作 。 首 先 ， 初 始 化 SESSION 变 
量 ， 连 接 数据 库 。 然 后 ， 对 表单 中 提交 的 数据 进行 判断 ， 判 断 用 户 注册 信息 是 否 为 空 及 用 户 名 是 否 被 占用 。 最 
后 ， 执 行 insert 添加 语句 ， 将 用 户 注册 的 信息 添加 到 数据 表 中 ， 并 且 通 过 setcookie0 函 数 创建 COOKIE 变量 存 
储 用 户 名 和 密码 。index_ok.php 的 关键 代码 如 下 : 


if($_POST [sub]) { // 判 断 按钮 的 值 ， 执 行 不 同 的 操作 
if($_POST [name] 一 "|$ POST [pwd]—""||$_POST [ym] =—="") { // 判 断 注册 信息 是 否 为 空 
echo "<script>alert( 注 册 信 息 不 能 为 空 );location href='index.php'</script>"; 
本 = "SELECT + FROM tb_form where name=".$_POST[name]"": /定义 查询 语句 
Srs = mysql_query ( $sql, $conn ); // 执 行 查询 操作 
Sresult=mysql_num rows($rs): /获取 查询 结果 
if($result>0){ // 如 果 查 询 结果 大 于 0， 说 明 用 户 名 被 占用 


echo "<script>alert( 用 户 名 被 占用 '):location.href='index.php':</script>"; 


} 
f($_POST [ym]--S$_ SESSION[ym]) { // 判 断 验 证 码 是 否 正 确 
mysql_query ( "INSERT INTO tb_form(name.pwd.last_date) VALUES(".$_POST [name'].".".$_POST[pwd].".nowO)" ): 
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setcookie(name'.$_POST [name]): // 创 建 COOKIE 变量 
setcookie(pwd',$_ POST[pwd].time()+60); /| 创建 COOKIE， 设 置 过 期 时 间 
echo "<script>alert( 注 册 成 功 ):window.location href='main php':</script>": 

}else{ 


ccho "<script>alert( 验 证 码 错误 ):windowlocation href-index php':</script>"; 
} 
} 
(3) 创建 main.php 文件 ， 注 册 成 功 后 通过 $_COOKIE 全 局 变量 获取 COOKIE 中 存储 的 用 户 名 和 密码 ， 其 


关键 代码 如 下 : 


<php 

echo "用 户 名 :".$_COOKIE[name']."<br>"; 
echo " 密 &nbsp;&nbsp: 码 : ". $_COOKIE[pwd']; 
?> 


(4) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 服务 器 和 db_database05 数据 库 的 连接 。 


图 秘笈 心 法 

心 法 领悟 260: COOKIE 文件 命名 。 

COOKIE 的 概念 最 早 是 由 Netscape 在 1994 年 提出 来 的 ， 是 指 保存 在 浏览 器 中 的 小 信息 包 。 更 确切 地 说 ， 
COOKIE 是 保存 在 用 户 硬盘 上 的 由 字符 串 组 成 的 小 文本 文件 。 


文本 文件 的 命令 格式 如 下 : 
用 户 名 @ 网 站 地 址 [数字 ].txt 


高 级 


站 | 
实例 261 趣味 指数 庚 良 志雄 ， 


图 实例 说 明 

COOKIE 具有 一 定 的 时 效 性 ， 当 超过 其 生命 周期 后 即 失效 。 但 是 ， 如 果 COOKIE 没有 超过 其 生命 周期 ， 那 
么 它 存储 在 客户 端的 数据 就 有 可 能 被 盗 取 。 所 以 ， 为 保护 信息 资源 ， 防 止 不 法 用 户 破译 ， 用 户 可 以 在 关闭 浏览 
器 之 前 ， 通 过 程序 自动 删除 存储 在 客户 端的 COOKIE。 本 实例 通过 setcookie0 函 数 实现 删除 客户 端 COOKIE 的 
功能 ， 其 运行 结果 如 图 5.10 所 示 。 
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图 5.10 删除 客户 端的 COOKIE 


力 关键 技术 


本 实例 运用 setcookie0O) 函 数 的 第 3 个 参数 值 ， 完 成 客户 端 COOKIE 的 删除 操作 。 因 为 setcookie0 函 数 的 第 3 
个 参数 是 用 来 设置 COOKIE 的 有 效 时 间 ， 所 以 如 果 设 置 一 个 小 于 系统 当前 时 间 的 有 效 期 , 那么 COOKIE 就 已 经 


过 期 ， 也 就 完成 了 客户 端 COOKIE 的 删除 操作 ， 其 关键 代码 如 下 : 
setcookie("name"."".time(|-1): 
这 里 设置 COOKIE 的 有 效 期 使 用 的 是 time0 函 数 ， 即 系统 当前 的 时 间 戳 ， 而 具体 的 有 效 期 值 是 time()-1。 
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国 设计 过 程 


(1) 创建 index.php 文件 ,编写 用 户 登录 页 面 ， 并 在 本 页 获取 用 户 的 登录 信息 ; 同时 通过 setcookie0 函 数 将 
用 户 登录 信息 存储 到 COOKIE 中 ， 并 且 根 据 表单 中 提交 的 值 设置 它 们 的 有 效 期 ， 其 关键 代码 如 下 : 


<?php 
sctcookie("usemame","$_POST[name]".(timeO+$_POST[check]): /创建 用 户 名 的 COOKIE 变量 
sctcookie("pwd","$_POST[pwd]",(timeO+$_POST[check]): // 创 建 密码 的 COOKIE 变量 


setcookie("IP"$_SERVER[REMOTE ADDR'],(time0+$ POST[check]): /创建 用 户 他 地 址 的 COOKIE 变量 
?> 


(2) 创建 main.php 文件 ， 设 计 网 站 的 主页 。 首 先 ， 判 断 COOKIE 变量 的 值 是 否 为 空 ， 如 果 不 为 空 则 可 以 
访问 本 页 的 内 容 ， 否 则 将 给 出 提示 信息 ， 并 跳 转 到 登录 页 面 。 然 后 ， 在 本 页 设置 删除 客户 端 COOKIE 的 超 链 接 ， 
当 单 击 “ 删 除 COOKIE ”图 片 链 接 时 ， 将 跳 转 到 本 页 ， 在 本 页 中 通过 setcookieO) 函 数 重新 设置 COOKIE 的 过 期 
时 间 为 time0-1， 以 删除 客户 端的 COOKIE ， 其 关键 代码 如 下 : 

a "&&S COOKIE[pwd1'="")f 
iflisset($_GET[cookie]){ 
setcookie("usemame","",time()-1); 
sctcookie("Ip","",time()-1); 
echo "<script>alert(COOKIE 已 删除 ， 确 认 退 出 ?人 );location href='index.php'</script>"; 
} 
?> 


国 秘笈 心 ; 
心 法 领悟 261: COOKIE 的 时 效 性 。 


在 编程 领域 , 程序 员 更 倾向 于 COOKIE 的 时 效 性 而 不 是 其 保存 信息 的 特性 。 因 为 COOKIE 以 明文 方式 保存 
信息 ， 为 了 安全 性 ， 程 序 员 更 喜欢 用 服务 器 端的 SESSION 机 制 来 保存 信息 。 


高 级 | 
趣味 指数 : odoholodl| 


实例 262 


力 实例 说 明 


有 很 多 用 户 提出 在 自己 硬盘 上 保存 不 明 数 据 会 带 来 安全 隐患 ， 所 以 用 户 可 以 关闭 COOKIE 功能 ， 并 且 从 硬 
盘 上 删除 COOKIE。 以 正 浏览 器 为 例 ， 可 以 选择 “工具 ”/“Internet 选项 ”命令 ， 在 弹出 的 对 话 框 中 选择 直接 
删除 COOKIE 文件 ， 如 图 5.11 所 示 。 
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图 5.11 删除 COOKIE 文件 


PHP 开发 实例 大 全 (基础 卷 ) 


国 关键 技术 


本 实例 的 关键 点 是 如 何在 客户 端 对 COOKIE 进行 控制 ， 其 具体 的 操作 方法 如 下 : 
以 正 浏览 器 为 例 ， 选 择 “ 工 具 ”/“Intemet 选项 ”命令 ， 在 弹出 的 对 话 框 中 选择 “隐私 ”选项 卡 ， 拖 动 隐 
私 设置 级 别 滑 块 ， 根 据 提示 设 定 想 要 的 隐私 级 别 ， 如 图 5.12 所 示 : 
3 3X 
党 规 | 安全 脱色 | 内 容 | 连接 | 程序 | 高 级 | 
站 设置 
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编辑 下 ) 


| 
5.12 阻止 所 有 COOKIE 


图 设计 过 程 

这 里 仍然 运用 实例 260 的 内 容 ， 在 用 户 注册 成 功 后 通过 COOKIE 变量 获取 用 户 的 注册 信息 。 在 本 实例 中 ， 
调整 客户 端 COOKIE 的 控制 权限 (方法 参见 关键 技术 ) ,然后 运行 实例 260 的 内 容 , 测试 在 客户 端 禁止 COOKIE 
的 情况 下 ， 是 否 可 以 获取 用 户 注册 成 功 后 COOKIE 变量 中 存储 的 用 户 注册 信息 。 

本 实例 的 实现 步骤 请 读者 参考 实例 260， 完 整 代码 请 参考 本 书 光盘 ， 这 里 不 再 熬 述 。 


国 秘笈 心 法 


心 法 领悟 262: 使 用 COOKIE 的 注意 事项 。 

(1) 在 应 用 setcookie0 函 数 之 前 ， 不 能 有 任何 HTML 输出 ， 如 果 用 户 犯 了 这 个 错误 ， 那 么 结果 可 想 而 知 ， 
随 之 而 来 的 肯定 是 一 堆 错 误 代 码 。 切 记 ， 即 使 是 空格 、 空 行 也 不 可 以 。 

(2) 通过 setcookie0 函 数 创建 COOKIE 后 ， 在 当前 页 应 用 echo 语句 输出 8_COOKIE 时 ， 不 会 有 任何 输出 。 
必须 在 刷新 后 或 者 浏览 下 一 个 页 面 时 才 可 以 看 到 COOKIE 的 值 ， 因 为 setcookie0 函 数 执行 后 ， 会 向 客户 端 发 送 
一 个 COOKIE， 如 果 不 刷新 或 者 浏览 下 一 个 页 面 ， 客 户 端 就 不 能 将 COOKIE 送 回 。 

(3) 一 个 浏览 器 最 多 能 创建 30 个 COOKIE， 并 且 每 个 COOKIE 的 容量 不 能 超过 4KB; 每 个 Web 站 点 能 
设置 的 COOKIE 总 数 不 能 超过 20 个 。 


5.2 SESSION 应 用 


SESSION 又 被 称 为 会 话 ， 是 指 用 户 访问 Web 站 点 时 的 一 系列 动作 。PHP 提供 管理 会 话 的 机 制 ， 可 以 追踪 
到 用 户 在 这 一 时 期 的 动作 ， 显 示 出 用 户 喜 欢 什么 、 需 要 什么 等 。 与 COOKIE 相 比 ， 会 话 更 加 强大 ， 不 但 能 够 管 
理 大 量 数据 ， 而 且 可 以 将 信息 保存 在 服务 器 端 ， 相 对 更 安全 并 且 没 有 存储 长 度 的 限制 。 
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实例 263 


力 实例 说 明 


在 论坛 中 ， 如 果 是 管理 员 ， 则 可 以 发 布 公告 信息 ， 如 果 是 普通 用 户 则 不 可 以 。 那 么 程序 是 如 何 对 登录 用 户 
的 权限 进行 判断 的 呢 ? 这 就 是 本 实例 将 要 向 大 家 介绍 的 技术 , 即 通过 SESSION 变量 掌控 登录 用 户 的 权限 。 如 果 
是 管理 员 登 录 ， 则 可 以 添加 公告 信息 ， 而 如 果 是 普通 用 户 ， 则 只 可 以 浏览 论坛 中 的 帖子 ， 其 运行 结果 如 图 5.13 
和 图 5.14 所 示 。 
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图 5.13 管理 员 登 录 图 5.14 发 布 留言 


如 图 5.14 所 示 ， 以 管理 员 身份 登录 到 main php 主页 后 ， 可 以 单 击 “ 留 言 ”， 发 布 留言 信息 ; 如 果 是 以 普通 
用 户 身 份 登录 ， 那 么 在 main.php 主页 中 “留言 ”是 不 可 用 的 ， 因为 普通 用 户 不 具备 发 布 留 的 权限 。 


图 关键 技术 
(1) 应 用 SESSION， 首 先 要 初始 化 SESSION 变量 ， 使 用 的 是 session_start0 函 数 ， 其 语法 如 下 : 


bool session_ start ( void 
该 函数 判断 是 否 有 一 个 会 话 ID 存在 ， 如果 不 存在 就 创建 一 个 ; 如果 存 在 ， 则 将 这 个 已 注册 的 会 话 变量 载 入 
以 供 使 用 。 


(2) 创建 SESSION 变量 ， 应 用 预定 义 变量 9_ SESSION， 其 应 用 语法 如 下 : 
$_SESSION["name"] = "value"; 


通过 预定 义 变量 $_SESSION 定义 SESSION 变量 。"name" 表 示 设 置 变量 的 名 称 ，"value" 表 示 设 置 变量 的 值 。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 添 加 表单 ， 设 计 用 户 登 录 页 面 并 获取 表单 提交 的 用 户 名 和 密码 ， 在 本 页 中 对 用 


户 提交 的 数据 进行 判断 。 首 先 ， 初 始 化 SESSION 变量 ,判断 用 户 提 交 的 值 是 否 为 空 ， 若 不 为 空 ， 判 断 用 户 登录 
身份 ， 如 果 是 管理 员 则 为 SESSION 变量 type 赋值 0， 如 果 为 普通 用 户 则 为 SESSION 变量 type 赋值 1， 其 关键 


代码 如 下 : 
<2php 
session_start(); 
if($_POST['sub' -=tmue){ 
if($_POST['user]!="" && $_POST[pwd]!=""){ // 判 断 用 户 名 和 密码 是 否 为 空 
这 $_POST[user] 一 "mr &é& $_POST['pwd}—"mrsoft"){ // 判 断 是 否 为 管理 员 
S$ SS 0; // 为 SESSION 变量 赋值 0 


o "<script>alert( 管 理 员 登 录 成 功 ! ): window.location href~'main php':</script>"; 
二 人 
$_SESSION[type] = 1: // 如 果 不 是 管理 员 ， 为 SESSION 变量 赋值 1 
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echo "<script>alert( 用 户 名 登录 成 功 ! ): window .location href=main php':</script>": 


ee =$ POST[user]: /将 登录 用 户 名 存储 到 SESSION 变量 user 中 
$ SESSION[pwd]=$ POST[pwd]: /将 登录 密码 存储 到 SESSION 变量 pwd 中 
else; 
ee "<script>alert( 用 户 名 和 密码 不 能 为 空 ! ); window.location.href='index.php':</script>"; 
} 
} 
es 
(2) 创建 main.php 文件 ， 编 写 网 站 的 主页 面 。 首 先 初始 化 SESSION 变量 ， 然 后 根据 SESSION 变量 type 
的 值 定义 页 面 的 输出 内 容 , 如 果 SESSION 变量 的 值 为 0, 则 说 明 登 录用 户 是 管理 员 , 那么 具备 发 布 公告 的 权限 ; 
如 果 SESSION 变量 的 值 为 1， 则 说 明 登 录用 户 是 普通 用 户 ， 那 么 就 不 具备 发 布 公告 的 权限 ， 即 控制 发 布 公告 的 
超 链 接 不 输出 ， 其 关键 代码 如 下 : 


php 
session_start(); // 初 始 化 SESSION 变量 
?> 
?php 
if($_SESSION['type']=="0"){ /根据 SESSION 变量 type 的 值 决 定 是 否 输出 发 布 公 告 的 超 链接 


> 
<area shape="rect" coords="330,64,385,100" href="mes.php" /> 
人 


> 
(3) 创建 mes.php 文件 ， 编 写 发 布 公告 信息 的 页 面 ， 根 据 SESSION 变量 type 的 值 决定 用 户 是 否 具有 访问 
此 页 面 的 权限 。 


图 秘笈 心 法 
心 法 领悟 263: SESSION 的 生命 周期 。 


SESSION 的 生命 周期 是 指 从 用 户 访问 页 面 开始 到 断 开 与 网 站 的 连接 为 止 。 在 用 户 每 次 连接 时 ，PHP 都 会 自 
动 生成 一 个 唯一 的 SESSION ID 以 标识 当前 用 户 与 其 他 用 户 。 
高 级 | 


实例 264 趣味 指数 : 请 请 请 户 | 


实例 说 明 

计数 器 用 来 统计 一 个 网 站 被 访问 的 次 数 ， 体 现 了 一 个 网 站 受 关注 的 程度 。 本 实例 将 向 大 家 介绍 如 何 制 作 计 
数 器， 以 及 如 何 屏蔽 刷新 页 面 对 计 数 器 的 影响 。 在 本 实例 中 ， 当 用 户 访问 页 面 时 计数 器 的 值 会 增加 一 次 ， 之 后 
无 论 如 何 刷新 页 面 , 计数 器 的 值 都 不 会 再 次 增加 , 只 有 重新 打开 页 面 才 会 发 生变 化 , 本 实例 的 运行 结果 如 图 5.15 
所 示 。 


加 站 的 访 阅 量 :73 
5.15 SESSION 变量 屏蔽 页 面 刷新 对 计数 器 的 影响 


图 关键 技术 


SESSION 变量 控制 重复 计数 的 原理 如 下 : 在 当前 页 面 被 访问 时 , 初始 化 一 个 SESSION 变量 , 判断 SESSION 
变量 的 值 是 否 为 空 ， 如 果 为 空 ， 则 将 计数 器 的 值 增加 1， 并 且 将 SESSION 变量 赋值 为 1。 此 时 ， 在 当前 页 中 
SESSION 变量 的 值 已 经 不 为 空 ， 无 论 如 何 刷新 ， 其 值 都 不 会 改变 ， 计 数 器 的 值 也 不 会 增加 。 
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图 设计 过 程 


(1) 创建 index.php 文件 ， 输 出 网 页 当前 的 访问 量 。 首 先 初始 化 一 个 SESSION 变量 ， 然 后 判断 SESSION 


变量 的 值 是 否 为 室 ， 如 果 值 为 室 ， 则 打开 指定 的 文本 文件 ， 读 取 其 中 存储 的 数据 ， 并 且 将 文本 文件 中 的 数据 值 
增加 1， 同 时 将 新 的 数据 写 入 文本 文件 中 ， 关 闭 文件 。 最 后 将 SESSION 变量 赋值 为 1， 其 关键 代码 如 下 ; 


<?php session start0; 
这 $_ SESSION[temp] 一 ""){ 1/ 判断 $_SESSION[temp] 一 "的 值 是 否 为 空 ， 其 中 的 temp 为 自 定义 的 变量 
if(($fp=fopen("counter txt","r"))=—false){ 
echo "打开 文件 失败 1"; 
Jelse{ 
S$counter=fgets($fp.1024): // 读 取 文 件 中 的 数据 
fclose($fp); /关闭 文本 文件 
$countertt; // 计 数 器 增加 1 
S$fp=fopen("counter.txt","w"); /以 写 的 方式 打开 文本 文件 
fputs($fp,$counter); // 将 新 的 统计 数据 增加 1 
felose(Sfp); 1/ 关闭 文件 
} 
$_SESSION[temp]=1; // 登 录 以 后 ，$_SESSION[temp] 的 值 不 为 空 ， 给 $_SESSION[temp] 赋 一 个 值 1 


} 


> 
(2) 在 index.php 文件 中 ， 创 建 img 标签 ， 在 sre 属性 中 调用 gdl.php 文件 ， 完 成 网 站 访问 量 的 输出 。 
(3) 创建 gdl.php 文件 ， 通 过 文件 系统 函数 读 取 存 储 在 counter.txt 中 的 网 站 访问 量 的 数据 ， 并 通过 GD2 函 
数 输出 网 站 访问 量 的 数据 。 


图 秘笈 心 ; 


心 法 领悟 264: SESSION 屏蔽 页 面 刷 新 对 计数 器 影响 的 弊端 。 
SESSION 变量 防止 重复 计数 的 缺点 是 只 对 当前 页 面 有 效 ， 当 重新 打开 页 面 时 ， 计 数 器 的 值 仍然 会 增加 。 


高 级 


实例 265 趣味 指数 : 依依 育 弃 


力 实例 说 明 


SESSION 是 一 种 服务 器 端的 会 话机 制 ， 也 就 是 说 在 用 户 与 网 站 断 开 连 接 之 前 ， 分 配给 用 户 的 SESSION ID 
不 会 改变 ， 数 据 可 以 在 不 同 页 面 之 间 相互 传递 。 这 样 的 机 制 不 仅 大 大 减少 了 程序 员 的 工作 量 ， 还 使 程序 运行 
效率 得 到 提升 ， 使 代码 结构 更 加 清晰 。 本 实例 通过 SESSION 机 制 实 现在 不 同 页 面 之 间 传 递 数据 ， 其 运行 结果 
如 图 5.16 所 示 。 


狼 目 度假 村 


© 
© 
© 
© 


5.16 在 不 同 页 面 之 间 传 递 数据 
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图 关键 技术 


在 本 实例 中 ，SESSION 技术 的 应 用 如 下 : 

首先 ， 通 过 session_start0 函 数 初 始 化 SESSION 变量 。 然 后 ， 应 用 session_set_cookie_params() 函 数 设 置 
SESSION 的 过 期 时 间 。 接 着 ， 应 用 $_SESSION 全 局 变量 定义 SESSION 变量 的 值 。 最 后 ， 应 用 session_destroy() 
函数 删除 SESSION 变量 。 


session set_cookie params(0) 函 数 设 置 SESSION 的 过 期 时 间 ， 其 语法 如 下 : 
void session_set_cookic params( int lifetime [, string path [, string domain [, bool secure]]]) 
session_set_cookie_params () 函 数 的 参数 说 明 如 表 5.2 所 示 。 


表 5.2 ”session_set_cookie_params () 函 数 的 参数 说 明 


参 数 说 了 明 
lifetime 必要 参数 。COOKIE 的 生存 期 
path 可 省 参数 。COOKIE 的 有 效 路 径 
domain 可 省 参数 。COOKIE 的 有 效 域 


Secure 


可 省 参数 。COOKIE 在 安全 的 范围 内 被 发 送 


session_destroy0 函 数 结束 当前 的 会 话 ， 其 语法 如 下 : 


session_ destroyO; 
该 函数 清空 会 话 中 的 所 有 资源 ， 彻 底 销毁 SESSION。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 计 用 户 登 录 页 面 ， 并 将 用 户 登录 信息 提交 到 index_ok.php 文件 进行 处 理 。 
(2) 创建 index_ok.php 文件 ， 完 成 对 表单 中 提交 数据 的 处 理 。 首 先 ， 应 用 session_set_cookie_params() 
函数 根据 表单 中 的 提交 值 设置 SESSION 的 过 期 时 间 ， 并 初始 化 SESSION 变量 。 然 后 ， 在 本 页 中 获取 表单 中 


提交 的 用 户 登 录 信息 ， 判 断 管理 员 的 用 户 名 和 密码 是 否 正确 。 如 果 正 确 ， 通 过 $_SESSION 将 用 户 名 和 密码 存 
储 到 指定 的 SESSION 变量 中 ， 同 时 跳 转 到 网 站 主页 ; 如 果 不 正确 ， 则 给 出 提示 信息 ， 并 跳 转 到 登录 页 ， 其 关 


键 代码 如 下 : 
<?php 
session_set_cookie_params($_POST['check']); /设置 SESSION 的 过 期 时 间 
session_start(); // 初 始 化 SESSION 变量 
这 S$_POST[sub]){ 
if($_POST['user]!="" && $_POST['pwd']!=""){ // 判 断 用户 名 和 密码 是 否 为 空 
if($_POST['user]=—="mr" && $_POST['pwd']—"mrsoft"){ // 判 断 管理 员 用 户 名 和 密码 是 否 正确 


$_SESSION['user] =$_POST['user]: 
S$_SESSION[pwd]=S$_POST[pwd]: 
S$_SESSION[check] = $_POST['check']: 
echo "<script>alert(' 管 理 员 登 录 成 功 ! '):window.location href='ini.php'</script>"; 
jslsef 
echo "<script>alert( 用 户 名 或 者 密码 不 正确 ! ):window location href-index php'</script>"; 
} 
yelse{ 
echo "<script>alert( 登 录用 户 名 或 者 密码 不 能 为 空 ! ):window.location href='index.php'</script>"; 
. 
} 


3) 创建 iniphp 文件 ,编写 网 站 的 主页 面 。 在 网 站 主页 面 中 应 用 $_SESSION 获取 SESSION 变量 中 存储 
的 用 户 名 、 密 码 和 SESSION 的 有 效 时 间 ， 同 时 创建 用 户 退 出 的 超 链接 ， 链 接 到 logout.php 文件 ， 其 关键 代码 
如 下 : 
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<?php 
session_start(); 
echo "当前 时 间 : ". date(Y-m-d H:i:s)."<br>"; 
echo "用 户 名 : ".$_SESSION[user]."<br>"; 
echo "密码 : ".$_SESSION['pwd]."<br>"; 
echo "时 效 : ".$_SESSION['check]." 秒 <br>": 
echo "<a href-logoutphp> 退 出 </a>": 
?> 


(4) 创建 logoutphp 文件 ， 应 用 session_destroy0 函 数 结束 当前 会 话 ， 即 退出 登录 ， 其 关键 代码 如 下 : 
Ee 

session_destroy(); 

echo "<seript>alert( 退 出 登录 ! "window .location href-=index.php'</script>"; 

?> 


国 秘笈 心 法 

心 法 领悟 265: SESSION 的 启动 。 

启动 SESSION 有 两 种 方法 : 第 一 种 是 使 用 session_start0 函 数 ， 第 二 种 是 应 用 session register0 函 数 为 会 话 
登录 一 个 变量 来 隐 含 地 启动 会 话 。 笔 者 推荐 使 用 第 一 种 方法 ， 因 为 第 二 种 方法 的 运用 需要 设置 php.ini 文件 中 
Tegister_globals 的 值 为 ON， 否则 使 用 session_register0 函 数 启 动 会 话 会 弹出 一 个 错误 信息 。 


力 实例 说 明 


购物 车 是 在 网 上 购物 时 使 用 的 一 个 临时 存储 商品 的 “车 辆 ”， 为 我 们 在 网 上 购物 提供 很 大 的 方便 ， 不 用 担 
心 一 次 购买 多 个 商品 要 进行 多 次 提交 结算 的 操作 ， 可 以 将 商品 放 入 购物 车 中 ， 等 选 购 完 后 一 起 结算 。 本 实例 将 
介绍 SESSION 购物 车 的 实现 方法 ， 其 运行 结果 如 图 5.17 所 示 。 


相机 0 [ 更 0 各 量 二 了 项 
I 3500 E 更 9 数量 扣除 法 项 
< 仙 经 购买 清 全 风物 车 >> | 


图 5.17 SESSION 购物 车 


力 关键 技术 


SESSION 购物 车 ， 顾 名 思 义 主要 是 应 用 SESSION 变量 来 实现 的 。 而 所 谓 的 购物 车 就 是 通过 $_SESSION 创 
建 的 两 个 SESSION 变量 ， 其 中 goodsid 存储 商品 的 ID， goodsnum 存储 商品 的 数量 。 

购物 车 的 操作 流程 如 下 : 首先 登录 到 网 站 中 浏览 商品 ， 然 后 购买 指定 的 商品 ， 进 入 购物 车 页 面 ， 在 其 中 可 
以 实现 很 多 操作 ， 包 括 更 改 商 品 数量 、 删 除 商品 、 清 空 购 物 车 、 继 续 购物 等 ， 最 后 填写 收 货 人 信息 ， 生 成 订单 ， 
执行 订单 打印 、 预 览 和 提交 等 操作 。 具 体操 作 流 程 如 图 5.18 所 示 。 
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更 改 购物 车 
中 商品 数量 
删除 购物 车 
中 指定 商品 
向 起 由 省 
1 1 浏览 有 结算 生 
加 入 | 商品 各 | 购物 车 ats 如 | 成 订单 
用 户 查看 购物 车 内 商品 f 继续 购物 | 
商品 金额 小 计 
订 | | 订 
商品 金额 总 计 单 | | 音 
打 | | 预 
印 览 
工行 支付 


[一 一 一 -提交 订单 一 一 一 一 一 


取消 订单 


图 5.18 ”购物 车 操作 流程 
图 设计 过 程 
应 用 SESSION 技术 开发 购物 车 的 步骤 如 下 : 


(1) 创建 index.php 页 面 ， 实 现 商品 展示 功能 。 设 计 原理 是 : 从 数据 库 中 读 取 商 品 信息 ， 将 商品 信息 在 页 
面 中 进行 分 栏 、 分 页 显示 ， 并 且 为 商品 设置 购买 和 查看 购物 车 的 超 链接 ， 运 行 结果 如 图 5.19 所 示 。 


商品 4 个 每 页 3 个 第 1 页 共 > 页 下 页 上 -页 下 一 页 尾 页 
图 5.19 购物 车 商品 展示 页 面 

(2) 创建 by_commodity.php 文件 ， 实 现 购买 功能 ， 即 向 购物 车 中 添加 商品 。 首 先 创建 一 个 购物 车 ， 然 后 

判断 购物 车 中 是 否 为 空 ， 如 果 为 空 ， 则 将 商品 展示 页 中 “购买 ” 超 链接 传递 的 商品 ID 〈$_GET[id]) 和 数量 添 


加 到 购物 车 中 ， 如 果 不 为 空 ， 则 判断 要 添加 的 商品 ID 是 否 在 购物 车 中 已 经 存在 ， 如 果 存在 则 不 能 重复 添加 ， 否 
则 将 跳 转 到 shopping.php 购物 车 页 面 ， 其 代码 如 下 : 


<?php 
session_start(); // 初 始 化 SESSION 变量 
header ( "Content’1 -type: text/html; charset=UTF-8" ); // 设 置 文 件 编码 格式 
if($_SESSION["goodsid"}-—"" && $_SESSION["goodsnum"}—""){ // 判 断 SESSION 变量 是 否 为 空 
$_ SESSION["goodsid"]-$_GET["id"]"@"… /如果 SESSION 变量 为 空 ， 则 为 其 赋值 为 商品 的 ID， 并 以 @ 分 隔 
$_SESSION["goodsnum"]="1@": // 如 果 SESSION 变量 为 空 ， 则 为 其 赋值 为 1， 并 以 @ 分 隔 
Jelse{ // 如 果 SESSION 变量 不 为 空 
$array=cxplode("@".$_ SESSION["goodsid"]): // 以 “@” 为 分 隔 符 ， 将 SESSION 变量 中 的 数据 写 入 数组 中 
iflin_array($_GET["id"].$array)){ // 济 断 数组 中 是 否 存在 指定 的 ID 


二 人 Dihistory.backO:</scriptf> : 
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} 
/如 果 数 组 中 不 存在 指定 的 ID， 则 说 明 该 商品 还 没有 放 入 购物 车 中 
$_SESSION["goodsid"].=$_GET["id"]."@":; // 将 该 商品 添加 到 购物 车 中 
$_SESSION["goodsnum"].="1@"; // 更 改 商 品 数量 


} 
echo "<script>window.location href='shopping_car.php':</script>"; 


(3) 创建 shopping.php 购物 车 页 面 ， 对 购买 商品 进行 统计 ， 包 括 购买 商品 的 数量 、 每 种 商品 的 金额 和 总 金 
额 ， 并 且 实 现 删除 购物 车 中 商品 、 更 改 购物 车 中 商品 数量 和 清空 购物 车 的 功能 ， 同 时 设置 “继续 购买 ” 超 链接 ， 
其 代码 请 参考 本 书 光盘 。 

(4) 创建 change_commodity_counts.php 文件 ， 实 现 更 改 购物 车 中 商品 数量 的 功能 。 首 先 获取 shopping.php 
页 面 表单 中 提交 的 商品 数量 和 商品 ID， 然 后 通过 正则 表达 式 验证 商品 数量 是 否 为 正 整数 ， 最 后 根据 商品 ID 找 
到 指定 的 商品 更 改 商 品 数量 ， 并 返回 到 购物 车 页 面 ， 其 代码 如 下 : 


3 
session st 
header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
S$id=$_POST["id"]; // 获 取 商 品 人 D 
$num=$_POST["goodsnum"]; /获取 商品 数量 
Spreg="/^[0-9]*[0-9]$|^[0-9]*[0-9]$/"; /编写 正则 表达 式 
这 Soum 一 ""){ // 判 断 提交 的 值 是 否 为 空 
echo "<script>alert( 数量 不 能 为 空 !):history.back0;</script>"; 
exit' 
}else if(!preg_match($preg,$Snum,$str)){ // 判 断 提 交 的 数据 是 否 为 正 整数 
echo "<script>alert( 数 量 只 能 为 正 整数 !):history.backO:</script>"; 
exit; 


} 
Sarrayid=explode("@".$_SESSION["goodsid"]);: 
Sarraynum=explode("@".$_SESSION["goodsnum"]): 


Skey=array_search($id.$arrayid): // 在 数组 中 搜索 给 定 的 值 ， 如 果 成 功 则 返回 相应 的 键 名 
Sarraynum[$key]=$num:; /更 改 商 品 数量 
$_SESSION["goodsnum"]=implode("@",$arraynum); /更 改 商 品 数量 


2 "<script>window,location href='shopping_car.php':</script>"; 


5) 创建 delete_commodity.php 文件 ， 实 现 删除 购物 车 中 指定 商品 的 功能 。 首 先 获 取 超 链接 中 传递 的 商品 
ID， 然 后 将 SESSION 中 的 字符 串 数据 转换 成 数组 ， 并 根据 商品 ID 获取 指定 要 删除 的 商品 的 键 名 ， 最 后 根据 键 
名 为 指定 的 数组 赋 空 值 ， 并 重新 将 数组 添加 到 购物 车 中 ， 代 码 请 参考 本 书 光盘 。 

(6) 创建 clear_shopping_car.php 文件 , 实现 清空 购物 车 的 功能 。 即将 SESSION 变量 $ SESSION["goodsid"] 
和 $_SESSION["goodsnum"] 赋 空 值 ， 其 代码 如 下 : 


<?php 
session_start(); // 初 始 化 SESSION 变量 
header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
$_SESSION["goodsid"]="": /为 购物 车 的 ID 赋 空 值 
$_SESSION["goodsnum"]=""; /为 购物 车 数量 赋 空 值 
echo "<script>window ,location href='shopping_car.php':</script>"; // 完 成 清空 操作 ， 跳 转 到 购物 页 面 
J 
» We 
图 秘笈 心 法 


心 法 领悟 266: 初始 化 SESSION 变量 和 删除 SESSION 变量 。 

在 应 用 SESSION 变量 实现 购物 车 功能 时 ， 最 容易 出 现 的 一 个 错误 就 是 忘记 初始 化 SESSION 变量 ， 如 果 在 
文件 中 没有 初始 化 SESSION 变量 ， 那 么 在 页 面 之 间 就 获取 不 到 SESSION 变量 中 存储 的 数据 。 

在 实例 265 中 ， 应 用 session_destroy0 函 数 删除 SESSION， 而 在 本 实例 中 通过 直接 为 SESSION 变量 赋 空 值 
的 方法 清空 SESSION， 还 可 以 通过 unsetO 函 数 删除 指定 的 SESSION 变量 。 


unset ( $_SESSION['user] ) : 


也 可 以 通过 直接 为 $8_SESSION 赋 一 个 空 数 组 的 方式 清空 SESSION。 


$_SESSION = amay0 : 
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实例 267 趣味 指教 : 三 让 丰 宙 


力 实例 说 明 


SESSION 的 功能 十 分 强大 ， 这 一 点 在 业界 中 是 公认 的 。 但 是 越 是 功能 强大 或 者 技术 含量 高 的 方法 往往 执行 
条 件 也 越 苛刻 ，SESSION 技术 的 应 用 也 是 如 此 。 本 实例 我 们 将 解决 一 些 在 SESSION 应 用 中 常见 的 问题 ， 包 括 
session startO 函 数 的 应 用 限制 〈 其 错误 使 用 的 运行 结果 如 图 5.20 所 示 ) 和 使 用 COOKIE 函数 设置 SESSION 过 
期 时 间 时 需要 注意 的 事项 。 
习 无 标题 文档 - Nicrosoft Internet Explorer 


文件 中。 编 名 外 查看 WW 收藏) 工具 QD 天助 如 
地 址 四 ) [Sm /1/192. 168. 1. 59/mr/05/013/ 


Warning: session_start() [function.session-start]: Cannot 妆 


send session cache limiter - headers already sent (output 
started at F:\AppServ\www\MR\0S\013\index.php:2) ip 
FAppServwww MR'05\013\index.php on line 3 


Internet 


图 5.20 ”session_start0 函 数 使 用 限制 


图 关键 技术 


(1) session_start0 函 数 : 使 用 此 函数 之 前 浏览 器 不 能 有 任何 输出 ， 否 则 会 输出 如 图 5.20 所 示 的 错误 信息 。 
(2) 使 用 COOKIE 函数 为 SESSION 设 定 过 期 时 间 时 ， 首 先 要 确定 浏览 器 支持 COOKIE， 其 次 要 将 
session_start0 函 数 放 置 在 setcookie0 函 数 之 前 ， 否 则 客户 端 不 会 创建 COOKIE 文件 。 


力 设计 过 程 
(1) 创建 index.php 文件 ， 编 写 PHP 脚本 ， 并 应 用 echo 语句 在 session_start0) 函 数 之 前 输出 一 个 字符 串 ， 


echo “mrsoft"; /输出 一 个 字符 串 
session_start0: /初始 化 SESSION 变量 
当 运 行 本 代码 时 , 将 输出 如 图 5.20 所 示 的 错误 信息 , 将 echo 语句 放置 于 session_start0 函 数 之 后 即 可 解决 该 
问题 。 
(2) 利用 COOKIE 机 制 设置 SESSION 的 过 期 时 间 。 在 index.php 文件 中 ， 首 先 初始 化 SESSION 变量 ， 然 
后 定义 一 个 SESSION 变量 pic， 最 后 通过 setcookie0 函 数 设置 SESSION 变量 的 过 期 时 间 ， 其 代码 如 下 : 
We session_start(); // 启 动 SESSION 
$_SESSION[pic] = "mrsoft"; // 设 置 SESSION 变量 
setcookie("pi"."$_SESSION['pic']".time()+60): /设置 SESSION 的 过 期 时 间 
> 
运行 本 代码 ， 可 以 在 客户 端的 COOKIE 文件 夹 下 查看 到 创建 的 COOKIE 文件 。 但 是 ， 如 果 将 setcookie0 函 
数 放置 在 session_start0 函 数 之 前 ， 运 行 本 代码 ， 在 客户 端的 COOKIE 文件 夹 中 则 找 不 到 对 应 的 COOKIE 文件 。 


力 秘笈 心 法 
心 法 领悟 267: 通过 session_set_cookie_params0 〇 函数 延长 SESSION 的 生命 周期 。 


第 5 章 会 话 应 用 


在 开发 程序 的 过 程 中 可 能 会 遇 到 这 样 的 情况 ， 以 会 员 身份 登录 一 个 网 站 后 ， 若 停留 的 时 间 较 长 ， 再 在 这 个 
网 站 中 发 布 信息 时 ， 会 提示 “您 没有 登录 ， 请 登录 后 再 发 布 信息 ”， 之 所 以 会 出 现 此 类 问题 ， 是 因为 在 登录 时 
定义 的 SESSION 变量 已 经 过 期 ， 导 致 当前 用 户 不 可 用 ， 需 要 重新 登录 。 解 决 此 问题 最 好 的 方法 就 是 通过 
session_set_cookie_params() 函 数 延 长 SESSION 的 生命 周期 , 即 应 用 session_set_cookie_ params0 〇 函数 将 SESSION 
的 过 期 时 间 设 置 为 0。 读 者 不 妨 自己 试 一 试 ， 看 是 否 能 够 延长 SESSION 的 生命 周期 。 


实例 268 人 
图 实例 说 明 


在 Web 网 站 的 开发 过 程 中 ， 需 要 对 不 同 的 登录 用 户 设置 不 同 的 权限 。 如 果 是 管理 员 ， 则 可 以 登录 网 站 后 台 
管理 系统 ， 管 理 网 站 的 数据 ;如 果 是 普通 用 户 ， 则 只 有 浏览 网 站 的 权限 ， 不 可 以 进入 网 站 的 后 台 管 理 系统 。 在 
本 实例 中 ， 当 输入 正确 的 用 户 名 mr、 密 码 mrsoft 时 ， 将 输出 如 图 5.21 所 示 的 页 面 。 

如 果 直 接 访问 main.php 页 面 ， 即 以 普通 用 户 的 身份 访问 ， 那 么 将 输出 如 图 5.22 所 示 的 提示 信息 ， 并 跳 转 到 
首页 。 


“ 一 个 此 从 pnTARE 
和 CD 
ET 
mr 芝 理 册 何 录 成 功 | 2015 年 中 月 20 日 17:09:55 
™ 
训 过 学 
学 
图 5.21 管理 员 登 录 成 功 展示 的 页 面 5.22 ”普通 用 户 访问 main.php 的 效果 
图 关键 技术 


本 实例 的 关键 是 在 main.php 文件 中 判断 SESSION 变量 的 值 是 否 为 管理 员 的 用 户 名 和 密码 ， 如 果 是 ， 则 可 
以 访问 本 页 面 ， 和 否则 将 给 出 提示 信息 并 跳 转 到 登录 页 面 ， 其 关键 代码 如 下 


<?php 

session_start(): // 初 始 化 SESSION 变量 

这 $_SESSION[user] 一 "mr" || $_SESSION['pass]——"mrsoft"){ / 测 断 SESSION 变量 的 值 是 否 正确 
ey, 


…// 省 略 了 部 分 代码 


<?php 

jslse{ // 如 果 值 不 正确 ， 则 跳 转 到 首页 
echo "<script>alert(' 您 不 具备 访问 本 页 面 的 权限 1):window.location .href'index.php':</script>"; 

} 

?> 


图 设计 过 程 
(1) 创建 index.php 文件 ， 编 写 用 户 登录 页 面 ， 将 用 户 登 录 信息 提交 到 index_ok.php 文件 中 。 
(2) 创建 index_ok.php 文件 ， 初 始 化 SESSION 变量 ， 通 过 $ POST 方法 获取 表单 提交 的 用 户 名 和 密码 ， 
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完成 对 用 户 名 和 密码 的 验证 。 如 果 正 确 ， 则 将 用 户 名 和 密码 赋 给 SESSION 变量 ， 并 通过 JavaScript 脚本 跳 转 到 
main.php 页 面 ， 否则 ， 通 过 JavaScript 脚本 给 出 提示 信息 ， 跳 转 到 index.php 页 面 ， 其 代码 如 下 : 


<Iphp 
session_start(): // 初 始 化 SESSION 变量 

这 $_ POST[user] 一 "mr && $ POST['pass]—"mrsoft"){ // 济 断 提交 的 用 户 名 和 密码 是 否 正确 
$_SESSION['user]-$_POST['user]: // 如 果 正 确 ， 将 其 赋 给 SESSION 变量 


$_SESSION['pass]=$_POST['pass']: 
echo "<script>alert( 欢 迎 您 的 到 来!):window.location href='main.php':</script>"; 
Jelse{ 
echo "<script>alert( 您 输入 的 用 户 名 和 密码 不 正确 !):window location href='index.php':</script>"; 


(3) 创建 main.php 页 面 ， 初 始 化 SESSION 变量 ， 通 过 $_ SESSION 方法 获取 SESSION 变量 的 值 ， 并 判断 
其 是 否 为 真 ， 如 果 为 真 ， 则 输出 该 页 面 的 内 容 ， 和 否则， 通过 JavaScript 脚本 给 出 提示 信息 ， 跳 转 到 index.php 页 
面 。 其 代码 可 以 参考 本 实例 的 关键 技术 。 


国 秘笈 心 法 
心 法 领悟 268: 通过 SESSION 控制 网 站 后 台 管理 系统 的 权限 。 
本 实例 介绍 的 是 通过 SESSION 控制 用 户 访问 权限 的 方法 。 实 例 中 只 是 对 一 个 简单 的 main.php 页 面 设置 访 


问 权限 ， 在 实际 的 程序 开发 过 程 中 ， 可 以 将 其 扩展 到 整个 网 站 的 后 台 管理 系统 中 ， 即 对 网 站 后 台 管理 系统 中 的 
所 有 文件 增加 权限 的 访问 控制 ， 从 而 确保 后 台 管 理 系统 不 被 普通 用 户 访问 ， 保 证 网 站 数据 的 安全 。 


力 实例 说 明 


将 SESSION 数据 变量 存储 于 服务 器 端 是 一 种 较 安全 的 做 法 , 但 是 设想 一 下 , 像 校 内 网 这 样 的 日 访问 量 过 亿 ， 
拥有 用 户 1500 万 的 大 型 网 站 ， 如 果 将 所 有 用 户 的 SESSION 数据 全 部 存储 在 服务 器 端 ， 将 消耗 巨大 的 服务 器 资 
源 。 所 以 程序 员 在 制作 大 型 网 站 时 将 SESSION 存储 于 服务 器 端 虽然 安全 , 但 却 不 是 最 好 的 选择 。 如 果 将 SESSION 
数据 存储 于 数据 库 中 ， 那 么 就 可 以 减轻 服务 器 的 压力 ， 同 时 数据 也 是 比较 安全 的 。 这 就 是 本 实例 将 要 介绍 的 内 
容 一 一 如 何 将 SESSION 数据 存储 于 数据 库 中 ， 其 运行 结果 如 图 5.23 所 示 。 


| 呆 - sEssloN 


SESSIONL_ID SESSION YALUES SESSION_TINE 
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图 5.23 将 SESSION 存储 到 数据 库 


国 关键 技术 


将 SESSION_ID 存储 于 数据 库 中 ， 应 用 的 是 session_set save_ handler0) 函 数 。 该 函数 调用 自 定 义 函数 ， 完 成 
将 SESSION _ID 存储 于 数据 库 中 的 操作 ， 其 语法 如 下 : 


‘bool session_set_save_handler ( string open. string close. string read string write. string destroy, string ge) 


session_set_save_handler() 函 数 的 参数 说 明 如 表 5.3 所 示 。 


第 5 章 会 话 应 用 
表 5.3 session_set_save_handler() 函 数 的 参数 说 明 
说 明 
找到 SESSION 存储 地 址 ， 取 出 变量 名 称 


参数 


Open(save path.session name) 


close0 不 需要 参数 ， 关 闭 数据 库 

read(key) 读 取 SESSION 键 值 ，key 对 应 SESSION ID 
write(key,data) 其 中 data 对 应 设置 的 SESSION 变量 
destroy(key) 注销 SESSION 对 应 的 SESSION 键 值 


清除 过 期 的 SESSION 记录 


gc(expiry time) 


这 是 一 个 非常 特殊 的 函数 ， 因 为 一 般 函 数 的 参数 都 是 变量 ， 但 是 该 函数 的 参数 为 6 个 函数 。 


上 ED 说 明 : 在 本 实例 中 ， 编 写 了 6 个 自 定义 函数 作为 Session _set_save_handle0 函 数 的 参数 ， 自 定义 函数 的 语法 
请 参考 设计 过 程 。 


图 设计 过 程 

(1) 创建 index.php 文件 ， 编 写 用 户 登录 页 面 ， 将 数据 提交 到 index_ok.php 文件 中 。 

(2) 创建 index_ok.php 文件 ， 编 写 6 个 自 定义 函数 作为 session_set_save_handle0 函 数 的 参数 ， 同 时 
session_set_save_handle0) 函 数 将 表单 中 提交 的 用 户 名 和 密码 赋 给 SESSION 变量 ,登录 成 功 后 跳 转 到 main.php 页 


面 ， 其 关键 代码 如 下 : 
<?php 
function_openO{ 

global Sconn; 


$conn = mysql_conneet ( "localhost", "root", "111" ) or die ("连接 mysql 出 现 错误 " ); 
mysql_select_db ("db_database05", Sconn ) or die ("连接 数据 库 出 现 错误 " ); 

mysql_query ( "SET NAMES utf8" ); // 设 置 数据 库 编码 
retum(true); 


} 

function _closeO{ /关闭 数据 库 
global $conn; 
mysql_close($conn); 
retum(tme); 


} 
function_read(Skey){ 
global $conn; // 全 局 变量 $conn 连接 数据 库 
Stime = time(): // 设 定 当前 时 间 
$sql = "select session_data from tb_session where session_key = '$key' and session_time > $time"; 
Sresult = mysql_query($sql.$conn); 
Srow = mysql_fetch_array(Sresult): 
证 (Srowj{ 
return($row['session_data']): // 返 回 SESSION 名 称 及 内 容 
jelse{ 


} 
} 
function _write($key, $data){ /首先 判断 SESSION 是 否 失效 ， 如 果 失 效 则 重新 向 数据 库 中 添加 数据 


return(false): 


global $conn: 
Stime = 60+60: // 设 置 失效 时 间 
Soverdue_time = time0 + $time: // 得 到 UNIX 时 间 截 


$sql = "select session_data from tb_session where session key ='$key’ and session_ time > $overdue time": 
Sresult = mysql_query($sql,Sconn); 


if(mysql_num rows(S$result) — 0 ){ // 没 有 结果 
$sql = "insert into tb_session values('$key','$data'.Soverdue_ time)"; // 插 入 数据 库 SQL 语句 
Sresult = mysql_query($sql.Sconn); 
Jelse{ // 否 则 ， 更 新 SESSION 的 数据 
$sql = "update tb_session set session key = 'Skey'.session data= '$data'.session time = $overdue time where session key ='$key"; 
// 定 义 更 新 语句 


357 


PHP 开发 实例 大 全 (基础 卷 ) 
Sresult = mysql_query($sql.$conn): /执行 更 新 语句 


} 
retum(Sresult); /返回 标识 
} 
function_destroy($key){ 
global $conn; 
$sql = "delete from tb_session where session key ='$key"; // 删 除数 据 库 SQL 语句 
Sresult = mysql_query($sql,$conn): 
retum(Sresult); 
} 
function_overdue($expiry_time){ 
global $conn; 
Soverdue_time = time(); /| 将 参数 Sexpiry_time 赋值 为 当前 时 间 戳 
$sql = "delete from tb_session where $expiry_time < $overdue_time"; // 删 除数 据 库 SQL 语句 
Sresult = mysql_query($sql,$conn); 
retum($result); 
} 
Session_set_save_handler('_open'," close',’ read', write', destroy' overdue); 
session_start(); 
if($_POST['sub]=—="sub"){ 
这 $_POST[user] — "|| $_POST[pwd] — ""){ 
echo "<script>alert(' 用 户 名 或 者 密码 不 能 为 空 ! ); window .location href='index.php';</script>"; 
jelsef 
$_SESSION['user] = $_POST['user]; 
$_SESSION[pwd]=$ POST[pwd]: 
echo "<script>alert(' 登 录 成 功 ! ); window.location.href='main.php':</script>"; 
} 


} 
2 


(3) 创建 main.php 文件 ， 连 接 数 据 库 ， 通 过 while 语句 循环 输出 数据 库 中 存储 的 SESSION 数据 。 
(4) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 连 接 MySQL 数据 库 服 务 器 和 db_database05 数据 库 。 


心 法 领悟 269: 注意 SESSION 函数 运用 时 的 放置 顺序 。 
在 运行 SESSION 函数 时 要 特别 注意 它们 的 使 用 顺序 ,尤其 是 session_startO 函 数 , 在 运用 这 个 函数 之 前 浏览 
器 不 能 有 任何 输出 。 还 有 session_save_pathO0 和 session_set_cookie_params0 〇 函数 ， 都 必须 在 session_start0 函 数 之 


前 使 用 , 否则 就 没有 任何 意义 ,解决 这 个 问题 最 好 的 方法 就 是 通过 session_set_cookie_params0 〇 函数 延长 SESSION 
的 生命 周期 。 


2 = 
趣味 指数 : 傅 癸 诊 育 | 
图 实例 说 明 


SESSION 可 以 实现 数据 在 页 面 之 间 的 传递 ， 并 且 在 SESSION 的 生命 周期 中 一 直 有 效 。 在 本 实例 中 ， 将 运 
用 SESSION 的 这 个 特性 ， 编 写 一 个 简单 的 聊天 室 换 肤 功能 。 在 聊天 室 中 ,根据 提交 的 颜色 值 更 换 聊 天 室 的 背景 
颜色 ， 其 运行 结果 如 图 5.24 所 示 。 


天宇， 认 汪 8 万 这 中 呈 示 几 天 的 让 安 。 基 蔚 大 全 相机 天 室 的 可 则 


要 Lm 


[ 提 全 吉 区 生 痢 色 ， 它 的 古 到 攻读 三 村 


图 5.24 ”更换 聊 天 室 背 景 颜色 
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图 关键 技术 


本 实例 中 ， 首 先 获取 超 链接 中 传递 的 参数 值 ， 然 后 将 参数 值 赋 给 指定 的 SESSION 变量 ， 最 后 将 SESSION 
变量 设置 为 页 面 背景 颜色 bgcolor 的 值 ， 从 而 实现 聊天 室 背 景 颜色 的 更 换 ， 其 关键 代码 如 下 : 


<?php 
$_SESSION[bgcolor]-$_GET['col]:; // 将 超 链接 传递 的 参数 值 赋 给 SESSION 变量 
ey 


<body bgcolor="<?php if($_SESSION['bgcolor]-——""){echo "white";}else{echo $_SESSION['‘bgcolor]:}?>"> 
在 body 标记 中 ， 通 过 站 语 句 判断 SESSION 变量 的 值 ， 如 果 值 为 空 ， 则 设置 bgcolor 的 值 为 white; 否则 ， 
直接 将 SESSION 变量 作为 bgcolor 的 值 。 


图 设计 过 程 

(1) 创建 index.php 文件 ， 设 计 一 个 简单 的 聊天 室 页 面 ， 在 聊天 室 的 log 中 插入 一 个 颜色 选项 卡 图 片 ， 并 
为 每 种 颜色 设置 矩形 热点 链接 ， 链 接 到 index.php 文件 ， 同 时 定义 超 链接 参数 col， 参 数值 是 热点 链接 对 应 的 颜 
色 值 。 


(2) 在 index.php 文件 中 获取 超 链接 传递 的 参数 值 ， 并 将 其 赋 给 SESSION 变量 ， 然 后 根据 SESSION 变量 
的 值 设置 页 面 中 body 标记 的 bgcolor 的 值 ， 完 成 聊天 室 背景 颜色 的 更 换 。index.php 的 关键 代码 如 下 : 


<?php 
$_SESSION['bgcolor]=$_GET['col]; /获取 超 链接 传递 的 参数 值 ， 并 赋 给 SESSION 变量 
> 


<body bgcolor="<?php if($_SESSION['bgeolor]—"") {echo "white";}else {echo $_SESSION['bgcolor]:}?>"> 
/| 省 略 了 部 分 代码 

<map name="Map" id="Map"> 

<area shape="rect" coords="4,3,27,26" href="index.php?col=0066FF" /> 

<area shape="rect" coords="64,5,87.26" href="index.php?col=00CCFF" /> 

<area shape="rect" coords="31,34,55,56" href="index.php?col=999900" /> 

<area shape="rect" coords="218,64,237,85" href="index.php?col=CC9933" /> 

<area shape="rect" coords="184,33,209,55" href="index.php?col=CC6600" /> 

<area shape=" 3 coords="214,7.237.28" href=" ‘index.php?col=3399FF" /> 


<area shape=" ee coords="65,61,88,87" href="index.php?col=99CC33" /> 
<area shape="rect" coords="152,61,177,87" href="index.php?col=CC3333" /> 
</map> 

<lbody> 


力 秘笈 心 法 


心 法 领悟 270: 编程 思想 比 编程 技术 更 重要 。 

在 本 实例 中 只 是 将 聊天 室 作为 实例 开发 的 一 个 大 背景 ， 并 没有 实现 聊天 室 的 功能 ， 其 目的 是 展示 如 何 通过 
SESSION 设置 聊天 室 的 背景 颜色 。 本 方法 虽然 很 简单 ， 但 是 体现 的 是 页 面 换 肤 的 基本 原理 ， 在 具体 的 实战 开发 
中 ， 读 者 可 以 将 这 个 技术 进行 升华 ， 不 但 可 以 改变 背景 的 颜色 ， 而 且 可 以 对 图 片 进行 更 换 。 程 序 设计 的 原理 非 
常 简单 ， 难 的 是 如 何在 原理 的 基础 上 让 内 容 更 加 丰富 ， 这 就 要 求 程序 开发 者 有 自己 独到 的 开发 思想 。 


提高 网 站 访问 的 效率 


实例 271 


力 实例 说 明 


SESSION 缓存 将 网 页 中 的 内 容 临 时 存储 到 客户 端正 的 Temporary Intemet Files 文件 夹 下 。 当 网 页 被 第 一 次 
浏览 后 ， 页 面 的 部 分 内 容 在 规定 的 时 间 内 就 被 临时 存储 在 客户 端的 临时 文件 夹 中 ， 这 样 下 次 访问 此 页 面 时 ， 就 
可 以 直接 读 取 缓存 中 的 内 容 ， 从 而 提高 网 站 的 浏览 效率 。 但 是 如 果 不 对 SESSION 缓存 做 定期 处 理 ， 也 会 给 服务 
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器 带 来 压力 。 本 实例 将 讲解 SESSION 缓存 的 运用 和 清理 方法 ， 其 运行 结果 如 图 5.25 所 示 。 
请 理 SESSION 缓 存 


Ra 为 :DTiVate 
为 = 让) 


图 5.25 输出 缓存 信息 


图 关键 技术 


在 本 实例 中 应 用 session_cache_limiter() 函 数 创建 缓存 ， 应 用 session_save_path0 函 数 设置 缓存 文件 的 存储 路 
径 ， 应 用 session_cache_expiry0 函 数 设置 缓存 时 间 。 


session_cache_limiter() 函 数 用 于 创建 SESSION 缓存 ， 其 语法 如 下 : 
eT 


参数 cache_limiter 用 于 设置 缓存 的 方式 ， 参 数值 说 明 如 表 5.4 所 示 。 
表 5.4 cache_limiter 参数 值 的 说 明 


参 数 值 说 了 明 
nochache 不 设置 缓存 
private 私有 方式 
private nochache 私有 方式 ， 但 不 过 期 
public 公有 方式 


session_ cache _expire (0 函数， 用 于 设置 缓存 时 间 ， 其 语法 如 下 : 


| 

参数 new_cache_expire 为 可 选 参数 , 设置 SESSION 的 过 期 时 间 , 单位 为 分 钟 。 默认 过 期 时 间 是 180 分 钟 ( 即 
不 设置 参数 值 的 情况 下 ) 。 

session_save_path() 函 数 取 得 或 者 重新 配置 目前 SESSION 的 存储 路 径 ， 其 语法 如 下 : 


string session_save_path([string path]) 
如 果 设 置 参数 path, 表示 重新 设置 SESSION 的 存储 路 径 ; 如 果 不 设置 参数 path, 表示 直接 获取 当前 SESSION 
的 存储 路 径 。 


看 设计 过 程 
(1) 创建 index.php 文件 。 首 先 ， 定 义 SESSION 临时 缓存 文件 夹 路 径 并 开启 缓存 ， 设 置 缓存 时 间 为 30 分 
钟 ， 启 用 SESSION， 并 设置 SESSION 变量 ， 其 代码 如 下 : 


<?php 

$path = /tmp/: /定义 缓存 文件 的 临时 存储 路 径 
session_save_path($path); // 设 置 缓存 存储 路 径 
session_cache limiter('private’); // 设 置 缓存 方式 

S$session_cache = session_cache limiter(); /开启 缓存 
session_cache_expire(30): /定义 缓存 时 间 

$session_expire = session_cache_expire(); // 设 置 缓 存 时 间 

session_start(: /初始 化 SESSION 变量 
$_SESSION['cache] = $session_cache: // 为 SESSION 变量 赋值 


$_SESSION[ expire'] = $session_expire: 
> 
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(2) 在 index.php 文件 中 ， 获 取 并 输出 缓存 中 存储 的 数据 ， 创 建 超 链接 ， 执 行 清 理 缓存 的 操作 ， 清 理 方法 


是 为 $ SESSION 赋 一 个 空 数 组 值 ， 并 应 用 session_destroy0 函 数 彻底 删除 会 话 ， 其 关键 代码 如 下 : 
<Iphp 
echo "<a href = 'index.php?cache=0> 清 理 缓存 </a>"; 
if($ GET[cache] —"0"){ 
$_SESSION = array(); // 清 空 SESSION 
session_destroy(); /销毁 会 话 
echo "<script>alert( 清 理 SESSION 缓存 成 功 ):location href='http://www.mrbecd.com'</script>"; 
} 


> 
用 秘 航 心 法 
心 法 领悟 271: 运用 SESSION 缓存 的 注意 事项 。 

(1) SESSION 缓存 被 存储 于 客户 端 。 如 果 用 户 未 设 定 SESSION 缓存 的 临时 目录 ， 默 认 情 况 下 存储 于 客户 
端正 的 Temporary Internet Files 文件 夹 下 。 以 Windows XP 系统 为 例 ，Temporary Internet Files 文件 夹 所 在 路 径 
为 C:\Documents and Settings\Administrator\Local Settings\Temporary Internet Files。 

(2) 虽然 可 以 通过 缓存 时 间 函 数 设 置 缓存 过 期 时 间 , 但 是 在 过 期 之 后 并 不 能 删除 存储 在 客户 端 缓存 文件 夹 
中 的 缓存 文件 ， 缓 存 文件 的 删除 由 Windows 操作 系统 自行 控制 ， 或 者 由 用 户 手动 删除 。 

(3) session_save_path()、session_cache_limiter()、session_cache_expiry0 函 数 都 必须 在 session_start0 函 数 之 
前 调用 ， 和 否则 会 出 现 错误 。 
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控制 、 显 示 图 片 特性 
JpGraph 类 库 

GD2 困 数 库 


世 
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第 6 章 图 形 图 像 处 理 


6.1 图 像 与 统计 


图 像 与 数字 相 结合 ， 既 可 以 美化 页 面 ， 同 时 又 达到 了 突出 显示 的 效果 ， 可 谓 一 举 两 得 。 在 本 节 中 将 向 读者 
展示 图 像 与 统计 结合 的 妙用 ， 和 希望 对 读者 的 开发 和 学 习 有 所 帮助 。 


实例 
图 实例 说 明 
网 站 计数 器 的 形式 有 很 多 ， 图 形 计数 器 是 比较 常用 的 一 种 。PHP 制作 图 形 计 数 器 的 方法 主要 有 两 种 ， 一 种 
是 利用 GD2 函数 直接 绘制 图 形 ， 另 一 种 是 事先 将 图 形 用 图 形 绘制 工具 绘制 出 来 ， 然 后 用 PHP 代码 进行 调用 。 
本 例 将 采用 第 二 种 方式 实现 ， 统 计 网 页 的 访问 量 ， 其 运行 结果 如 图 6.1 所 示 。 
编程 词典 在 线 的 误 为 首页 国 尿 本 本 站 忠 联 系 我 们 


‘sa CHMOD ewe Rta 
全 业 精 神 : 博学、 记 新 . 求实 、 笃 行 


公司 狐 多 ;以 高 疡 法 为 信托 战略 性 地 开发 具有 巨大 市 场 潜力 的 忘 价值 的 产品 。 
公司 远景 ; 成 为 攻 肥 核心 革 卡 和 芒 产 品 的 高 科技 分 司 ， 在 革 比 误 具有 领先 的 市 场地 详 。， 
作价 值 观 ; 水 生计 情 、 每 一 天 都 芷 进步 ， 窜 忍 失败 ， 交 唱和 囊 、 充 分 信任 、 平 等 流 


图 6.1 图 形 计数 器 


图 关键 技术 


图 形 计数 器 的 设计 原理 : 

(1) 为 了 避免 用 户 通过 刷新 页 面 来 提高 网 站 的 访问 量 ， 通 过 SESSION 变量 防止 重复 计数 。 首 先 ， 通 过 判 
断 $_SESSION [temp] 的 值 是 否 为 空 决定 计数 器 的 值 是 否 加 1， 如 果 该 值 不 为 空 ， 说 明 用 户 正在 访问 该 网 站 ， 这 
时 计数 器 的 值 不 加 1， 反之 加 1。 

(2) 将 文本 文件 中 存储 的 访问 量 数据 以 数字 图 片 的 形式 输出 。 首先， 应 用 strlen0) 函 数 获取 文本 文件 中 数据 
的 长 度 。 然 后 ， 定 义 网 站 访问 量 的 最 大 值 为 6 位 数字 (当然 位 数 可 以 根据 实际 情况 设 定 ) ， 用 0 填充 剩余 位 数 。 
最 后 ， 通 过 for 循环 和 switch 语句， 将 从 文本 文件 中 读 取 的 数据 以 图 形 的 形式 输出 ， 其 关键 代码 如 下 : 


Slen = strlen ( $counter ); // 获 取 字 符 串 的 长 度 
S$str = str_repeat ( "0". 6 - $len ); /获取 6-Slen 个 数字 0 
for($i= 0: $i < strlen ( $str ); Si ++) { /获取 变量 Sstr 的 字符 串 长 度 
Sresult = $str [$i]; 
Sresult = "<img sre=images/0.gif>"; 
echo $result // 循 环 输出 Sresult 的 结果 
for($i= 0: $i < strlen ( $counter ): $1++) { /获取 字符 串 的 长 度 
Sresult = $counter [$i]:; 
switch ($result) { 
// 如 果 值 为 0， 则 输出 0.gif 图 片 
case "0" : 
Sret [$i] = "0.gif'; 
break: 


PHP 开发 实例 大 全 (基础 卷 ) 


Ome 
Sret [$1] = "1.gif’; 
es 
hse 2” 
Sret stBl= "2.gif'; 
/中 部 分 代 轩 “ 
} 
echo "<img src=images/". $ret [$i] . ".>"; /输出 文本 文件 中 存储 的 数据 
力 设计 过 程 


(1) 创建 index.php 页 ， 设 计 网 站 的 页 面 ， 输 出 公司 简介 的 内 容 。 
(2) 在 index.php 页 中 ， 通 过 文件 系统 函数 编写 一 个 文本 计数 器 ， 将 数据 存储 于 文本 文件 counter.txt 中 ， 
并 通过 SESSION 变量 屏蔽 页 面 刷 新 对 计数 器 的 影响 ， 其 关键 代码 如 下 : 


< 
a 0; 
if($_SESSION [temp] =—"") { // 判 断 $_SESSION[temp]j=="" 的 值 是 否 为 空 ， 其 中 temp 为 自 定义 的 变量 
证 (($ 印 = fopen ( "counter.txt", "r" )) — false) { 
echo "打开 文件 失败 1"; 
}else{ 
$counter = fgets ( $fp, 1024 ); // 读 取 文件 中 数据 
felose ( $f ); // 关 闭 文本 文件 
$counter ++; // 计 数 器 增加 1 
$fp = fopen ( "counter.txt", "w" ); // 以 写 的 方式 打开 文本 文件 
fputs ( $fp, $counter ); // 将 新 的 统计 数据 增加 1 
felose ( $f ); // 关 闭 文件 
人 SESSION [temp] = 1; // 为 $_SESSION[temp] 赋 一 个 值 
} 
> 


(3) 在 index.php 页 中 ， 通 过 文件 系统 函数 读 取 文 本 文件 中 存储 的 网 站 访问 量 的 数据 ， 并 将 数据 以 图 形 的 
形式 输出 。 代 码 请 参考 关键 技术 中 的 内 容 。 


国 秘笈 心 法 
心 法 领悟 272， 另 一 种 将 数字 转换 成 图 形 的 方法 。 
首先 ， 应 用 intval0 函 数 将 计数 器 的 值 转变 成 字符 串 。 设 置 计数 器 最 多 显示 8 位 数字 (当然 位 数 可 以 根据 实 


际 情况 设 定 ) ， 根 据 strlen0 函 数 确 定 当前 计数 值 的 位 数 ， 之 后 用 8 减 去 该 位 数值 得 出 剩余 的 位 数 ， 为 了 使 页 面 
美观 ， 剩 余 的 位 数值 用 0 填充 ， ns 其 关键 代码 如 下 : 


Simagenum=intval($num): 
for($i=0:$i<8-strlen($imagenum):$i++){ 
echo "<img src=images/count/0.gif>"; // 用 0 填充 剩余 的 位 数 
} 
for($i=0:$i<strlen($imagenum):$it+){ // 通 过 循环 调用 图 片 显 示 结 果 


echo "<img sre=images/count/".substr($imagenum.$i,1).".gif>"; 
} 


实 , 高 级 
an | pn wnt sant 
国 实例 说 明 


本 实例 向 读者 介绍 另 一 种 计数 器 ， 即 将 统计 数据 以 GD2 函数 生成 的 图 像 进行 输出 ， 本 实例 的 运行 结果 如 
图 6.2 所 示 。 
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出生 主页 国 必 半天 入 革 生 们 


图 6.2 GD2 图 形 计 数 器 


图 关键 技术 
本 实例 联合 应 用 文件 系统 函数 和 GD2 函数 ， 完 成 网 站 访问 量 的 存储 、 读 取 和 输出 ， 其 原理 如 图 6. 3 所 示 。 


直接 输出 
网 站 访问 量 
判断 SESSION 
是 否 为 空 


登录 创建 
ll 网 站 | SESSION 
浏览 者 < 人 > 
重新 输出 
网 站 访问 量 打开 文本 文件 
读 取 文件 中 数据 
以 写 入 方式 打开 文件 


将 数据 写 入 到 文件 中 |<”| 计数 器 值 加 ! [< 


6.3 GD2 图 形 计数 器 设计 原理 


在 这 个 通过 文本 文件 统计 网 站 访问 量 的 程序 中 ， 概 括 起 来 应 用 了 3 方面 的 技术 : 
加 ”文件 系统 操作 函数 ， 实 现 数据 的 写 入 、 读 取 功 能 。 
回 SESSION， 通 过 SESSION 变量 防止 重复 计数 。 
加 ”GD2 函数 ， 将 访问 量 数 据 生成 图 像 ， 改 变数 据 的 输出 方式 。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 完 成 页 面 的 设计 ， 通 过 文件 系统 函数 将 网 站 的 访问 量 添加 到 文本 文件 counter.txt 
中 ， 并 且 通 过 SESSION 变量 屏蔽 刷新 功能 对 计数 器 的 影响 。 创 建 <img> 标 签 ， 链 接 到 gd2.php 文件 ， 在 该 文件 
中 将 网 站 访问 量 的 数据 生成 图 像 。 
(2) 创建 gd2.php 文件 ， 应 用 GD2 函数 将 从 文本 文件 中 读 取 到 的 数据 生成 图 像 。 其 中 ， 关 键 是 运用 
imagettftext0 和 imagestringO) 函 数 ， 完 成 对 中 文字 符 串 和 英文 字符 串 的 输出 ， 其 关键 代码 如 下 : 
< 了 
加 的 形式 给 册 数据库 中 的 记录 数 
header("Content-type: text/html:; charset=UTF-8"); // 设 置 文件 编码 格式 
if(Sfp=fopen("counter.txt","r"))—false){ 
echo "打开 文件 失败 1"; 
Jelse{ 
$counter=fgets($fp.1024); 
fclose($fp): 


Sim=imagecreate(240.24); /通过 GD2 函数 创建 画布 
Sgray=imagecolorallocate($im.255,255.255); 

S$color =imagecolorallocate($im.rand(0.255).rand(0.255).rand(0.255)): /定义 字体 颜色 
Stext=" 网 站 的 访问 量 :"; // 定 义 中 文字 符 串 

Sfont = "FontsFZHCJW.TTEF"; 

imagettftext($im,14.0.20.18.$color.$font. $text): /| 输出 中 文 
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imagestring($im.5,160,5.$counter, Scolor): /| 输出 网 站 的 访问 次 数 
imagepng($im): 
imagedestroy(Sim); 
} 
?> 


心 法 领悟 273: 通过 imagettftext0 函 数 输出 中 文字 符 串 。 

在 通过 imagettftextO 函 数 输出 中 文字 符 串 时 ， 如 果 页 面 使 用 的 是 UTF-8 编码 ， 那么 可 以 直接 使 用 这 个 函数 ; 
如 果 页 面 中 使 用 的 是 GB2312 或 者 其 他 编码 ， 那 么 就 必须 应 用 iconv0 函 数 对 要 输出 的 中 文字 符 串 的 编码 进行 转 
换 ， 因 为 imagettftext0 函 数 只 支持 UTF-8 编码 。 


ia 
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实例 说 明 


在 线 调查 中 的 投票 系统 相信 大 家 都 了 解 ， 在 本 实例 中 ， 将 编写 一 个 简易 的 投票 系统 ， 并 将 投票 结果 以 图 像 
的 形式 进行 输出 ， 运 行 效果 如 图 6.4 所 示 。 


图 6.4 输出 投票 结果 


图 关键 技术 


投票 系统 包括 动态 生成 投票 主题 、 动 态 添加 投票 选项 内 容 、 投 票 主题 管理 和 投票 功能 实现 。 这 里 重点 介绍 
在 投票 功能 中 如 何以 图 像 的 形式 输出 投票 结果 。 

在 look_vote.php 文件 中 , 根据 总 的 投票 数 , 计算 出 每 一 项 所 占 的 比例 , 然后 根据 这 个 比例 计算 输出 的 图 像 ， 
其 关键 代码 如 下 : 


<?php 

$sql="select * from tb_vote where tb_vote_id="$_GET[id]"; // 显 示 指 定投 票 项 

$result=mysql_query($sql.$conn); // 执 行 查询 指定 的 投票 选项 

Srow=mysql_fetch_array($result): // 获 取 查 询 结果 

$s=$row[tb_vote_num]: /计算 总 的 投票 数量 

echo "$row[tb_vote_name]\n"; /输出 投票 选项 的 名 称 

> 

<?php 

这 Srows[tb_record_num] 一 0) // 判 断 如 果 投票 数 为 0 

$width=0: /定义 变量 值 为 0 

else 

Swidth=$rows[tb_record_num]/$s; // 否 则 ， 根 据 投票 数 和 总 的 投票 数 计 算 输出 所 占 比例 

if($width!=0){ // 以 图 像 的 形式 输出 投票 所 占 比例 
echo "<img src=".Srows[tb_record_colorl "bmp width=".($width*20)." height=10>\n"; 

} 

echo $rows[tb_record_num]."/".$row[tb_vote_num]: /以 数字 输出 投票 数 和 总 的 投票 量 

?> 
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国 设计 过 程 
本 实例 的 文件 架构 如 图 6.5 所 示 。 


图 6.5 投票 系统 的 文件 架构 


上 说 明 : 本 实例 编写 一 个 简易 的 投票 系统 ， 具 体内 容 请 参考 本 书 光盘 ， 这 里 只 对 其 中 投票 结果 的 图 像 输出 进 
行 讲解 。 


这 里 重点 介绍 look_vote.php 文件 ， 在 该 文件 中 完成 投票 的 提交 操作 和 投票 结果 的 输出 。 首 先 根据 超 链接 传 
递 的 ID， 查 询 出 指定 的 投票 主题 ， 并 计算 出 投票 总 数 。 然 后 创建 表单 ， 提 交 投 票选 项 ， 将 数据 提交 到 
look vote_okphp 页 进行 处 理 。 最 后 执行 查询 语句 ， 从 数据 库 中 查询 出 投票 结果 ， 并 完成 投票 结果 的 输出 ， 其 关 
键 代码 如 下 : 


<2php 

include_once ("conn/conn.php"): 
if(!$_GET [id]) { 

echo "没有 指定 ID! "; 


?> 

// 执 行 查询 ， 输 出 投票 主题 

<2php 

$sql = "select * from tb_vote where tb_vote_id='$_GET[id]"; // 显 示 指 定投 票 项 
Sresult = mysql_query ( $sql. $conn ): 

Srow = mysql fetch_array ( $result ); 

$s = $row [tb_vote_num]; 

echo "$rowltb vote namel\n"; 

2> 

// 创 建 表单 ， 提 交 投 票选 项 

<form action=look_vote_ok.php method=post> 

<input type=hidden name=id value="<?php echo $row [tb_vote idj: ?>"> 
<input type=hidden name=v_type value="<?php echo $row [tb_vote_ type]; ?>"> 
</form> 

/| 输出 投票 结果 


<?pbp 
$sql2 = "select * from tb_vote_record where tb_vote_id='$_GET[id]": 
Sresult2 = mysql_query ( $sql2. $conn ): 
while ( $rows =mysql fetch array ( $result2 )) { 
We 


<tr> 
<td height="25" align="center"> 
<Iphp 


if ($row [tb_vote type] 一 0){ 

echo "<input type=radio name=r value=" . Srows [tb_record id] . ">\n"; 
yelsef 

echo "<input type=checkbox name=r[] value=" . $rows [tb_record id] . ">\n"; 


2></td> 
<td>&nbsp:<?php echo $rows [tb_record_name]: ?></td> 
<td>&nbsp: 
<?php 
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($rows [tb_record_num] — 0) 
Swidth= 0; 
else 
Swidth = $rows [tb_record_num] / $s; 
(Swidth =0) { 
echo "<img sre=" . $rows [tb_record_color] . "bmp width=" . ($width * 20) . " height=10>\n"; 
} 
echo $rows [tb record num]."/". $row [tb vote numl; 
2></td> 
</> 
<?php 
} 


?> 
<?php 
} 


和 
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心 法 领悟 274: 如 何 屏蔽 同一 个 用 户 的 重复 投票 。 
在 本 实例 的 简易 投票 系统 中 ,应 用 SESSION 变量 来 屏蔽 同一 用 户 的 重复 投票 ， 可 以 防止 用 户 在 一 次 访问 


中 进行 重复 投票 。 不 过 本 系统 也 存在 一 个 问题 ， 即 如 果 同 一 个 用 户 想 再 次 投票 ， 只 要 关闭 当前 页 面 ， 重 新 登录 
即 可 。 


中 级 | 
实例 275 起 味 指数 : 庚 友 祥 窑 
实例 说 明 


在 本 实例 中 将 介绍 图 像 的 另 一 项 妙用 ， 即 显示 注册 填写 密码 的 安全 强度 。 运 行 本 实例 ， 当 在 密码 文本 框 中 
输入 一 个 密码 时 ， 光 标 离开 后 将 自动 判断 这 个 密码 的 安全 强度 ， 并 以 图 像 的 形式 返回 一 个 判断 结果 ， 其 运行 结 
果 如 图 6.6 所 示 。 
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国 上 有 
电话 导 码 的 格式 下 正确 ? 


EI 
图 6.6 通过 图 像 显示 密码 安全 强度 
力 关键 技术 
对 密码 安全 强度 进行 判断 是 在 JavaScript 脚本 中 应 用 正则 表达 式 来 完成 的 ， 其 原理 如 下 : 
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(1) 对 密码 中 的 值 进行 判断 ， 如 果 只 包含 数字 、 英 文字 符 串 或 者 特殊 字符 串 中 的 任意 一 种 ， 那 么 说 明 密码 
ts 如 果 包 含 数字 、 英 文字 符 串 或 者 特殊 字符 串 中 的 任意 两 种 ， 那 么 说 明 密 码 安 
TE, 如 果 同 时 包含 数字 、 英 文字 符 串 和 特殊 字符 串 ， 那 么 说 明 密码 安全 强 
5 JavaScript 脚本 中 ， 通 过 search0 方 法 调用 正则 表达 式 完成 对 密码 值 的 判断 ， 其 关键 代码 如 下 : 


var pl = (form.pwd.value.search(/[a-zA-2]/)!=-1)?1:0; // 判 断 密码 中 是 否 包含 英文 字符 串 
var p2 = (form.pwd.value.search(/[0-9]/)!=-1)?1: // 判 断 密码 中 是 否 包含 数字 
var p3 = (fomm pwdvalue search([^a-zA-Z0-9 J/)!=-1)?1:0; // 判 断 密码 中 是 否 包含 特殊 字符 
varp =pl+p2+p3; // 定 义 判断 的 返回 值 
这 p 一 1){ 

chknew_pwd.innerHTML="<img src='images/1_03jpg>": // 输 出 密码 安全 强度 差 的 图 像 
jelse if(p—2){ 

chknew_pwd.innerHTML="<img sre='images/2_03.jpg>"; // 输 出 密码 安全 强度 中 的 图 像 
Jelse re 

chknew_pwd innerHTML="<img sre='images/3_03.jpg>"; // 输 出 密码 安全 强度 强 的 图 像 


} 
图 设计 过 程 

本 实例 完成 一 个 用 户 注册 的 功能 , 并 且 在 表单 中 通过 JavaScript 脚本 对 提交 的 元 素 进 行 判 断 , 最 终 符合 要 求 
后 ， 将 用 户 注册 信息 添加 到 指定 的 数据 表 中 。 

(1) 创建 index.php 页 面 ， 完 成 用 户 注册 页 面 和 表单 的 设计 。 通 过 JavaScript 对 表单 中 提交 的 值 进行 判断 ， 


并 直接 将 判断 的 结果 反馈 到 <div> 标 签 中 ， 最 终 将 表单 中 的 数据 提交 到 index_ok.php 文件 中 ， 完 成 用 户 注册 的 
操作 。 


<form name="form_reg" method="post" action="index_ok .php" onSubmit="return chkreginfo(form_reg,'all)"> 
<u> 
<td height="30"><div align="right"> 密 码 ，</div></td> 
<td height="30" colspan="2" align="left">&nbsp: 
<input type="password" name="pwd" id="pwd" size="30" class="inputess" 
onBlur="chkreginfo(form_reg.1)"> <font color="#FF0000">+</font>&nbsp: 
<div id="chknew_pwd" style="color: #FF0000"></div> 
<ltd> 
</t> 
<tr> 
<td height="30">&nbsp:</td> 
<td width="150" height="30"><input type="image" sre="images/form O jpg"> &nbsp:&nbsp:<ltd> 
<td width="343"><img src="images/form jpg" width="72" height="26， 
onClick="formm_regreset0" style="cursor: hand" /></td> 
<ltr> 
</form> 


(2) 编写 JavaScript 脚本 ， 创 建 checkjs 脚本 文件 ， 完 成 对 表单 中 提交 的 值 进行 判断 。 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 将 数据 添加 到 指定 的 数据 表 中 。 
(4) 创建 conn.php 文件 ， 完 成 MySQL 服务 器 和 MySQL 数据 库 的 连接 操作 ， 并 设置 编码 格式 为 UTF-8。 
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心 法 领悟 275: 正则 表达 式 的 运用 。 
在 本 实例 中 多 次 使 用 了 正则 表达 式 ， 分 别 通 过 正则 表达 式 对 密码 的 强度 进行 判断 、 对 手机 号 码 进行 判断 、 
对 座机 号 码 进行 判断 以 及 对 邮箱 地 址 进行 判断 。 


Al130df95D3P150d{99D31890d{893/ // 判 断 手机 号 码 
/0d{37)0d{8D5"0d{4}-)0d{07DSI0d{4}-)0d{sDs/ // 判 断 座机 号 码 
Net (Lt J wt)*@ et Jet) * wt (Jt)*/ // 判 断 邮 箱 
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实例 276 


力 实例 说 明 


为 了 防止 用 户 通过 恶意 程序 登录 站 点 ， 提 高 网 站 的 安全 性 ， 项 目 开发 时 ， 在 用 户 登 录 、 注 册 以 及 发 表 主 题 
等 模块 中 加 入 验证 码 模 块 是 必 不 可 少 的 。 应 用 验证 码 技术 ， 可 以 有 效 地 防止 用 户 通过 探测 的 方式 非法 登录 ， 从 
而 有 效 地 提高 站 点 的 安全 性 。 在 本 实例 中 ， 应 用 JavaScript 技术 及 0~9 这 10 个 别致 数字 图 片 为 博客 的 后 台 登 录 
设计 验证 码 功能 ， 其 运行 效果 如 图 6.7 所 示 。 


用 PP 和 :区 mn: 32 和 ET 
my El 


6.7 ”数字 图 像 验证 码 


图 关键 技术 


首先 ， 通 过 JavaScript 中 Math 对 象 的 random() 方 法 随机 生成 4 位 随机 数 ， 并 通过 doument 对 象 的 write0 方 
法 将 这 4 位 随机 数 所 对 应 的 图 片 以 链接 形式 输出 ， 链 接地 址 为 某 PHP 页 面 ， 然 后 ， 通 过 $_GET[] 全 局 数组 提取 
链接 地 址 所 传 入 的 随机 数值 ， 通 过 PHP 文件 操作 函数 读 取 该 随机 数 对 应 的 图 片 ， 并 以 二 进 制 的 形式 输出 到 浏览 
器 。 接 着 ， 定 义 一 个 重新 指定 图 片 链接 地 址 的 方法 ， 当 单 击 “ 看 不 清 ”链接 时 ， 调 用 该 方法 生成 新 的 验证 码 图 
片 。 最 后 , 在 表单 中 添加 一 个 隐藏 域 , 用 于 提交 4 位 随机 数 , 当 用 户 单 击 表单 中 的 “登录 ”按钮 时 , 通过 JavaScript 
将 隐藏 域 的 值 与 验证 码 文本 框 所 输入 的 内 容 进 行 比较 ， 完 成 验证 操作 。 

本 实例 的 关键 技术 主要 是 通过 JavaScript 随机 生成 4 位 随机 数 , 以 及 如 何 将 随机 数 对 应 的 图 片 以 二 进 制 的 形 
式 输出 到 浏览 器 。 

(1) 创建 4 位 随机 数 


通过 JavaScript 中 Math 对 象 的 random() 方 法 随机 生成 4 位 随机 数 ， 关 键 代码 如 下 : 
var numl=Math round(Math random0*10000000): 
var num=numl.toStringO.substr(0.4): /生成 4 位 随机 数 


(2) 将 图 片 以 二 进 制 形式 输出 

应 用 PHP 的 文件 操作 函数 即 可 实现 将 图 片 以 二 进 制 的 形式 输出 到 浏览 器 ,本 实例 主要 应 用 fread0 函 数 实现 ， 
函数 语法 如 下 : 

fread ( int handle, int length) 

参数 说 明 : 

handle: fopen0 函 数 打开 文件 后 所 返回 的 文件 句柄 。 

length: 所 读 取 文 件 的 长 度 。 

例如 ， 本 实例 中 应 用 fread0 方 法 将 图 片 以 二 进 制 形式 输出 到 浏览 器 ， 实 现代 码 如 下 : 


里 
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Sfp=fopen($address,"r"); /打开 文件 
echo fread($fp.filesize($address)): // 读 取 文件 
力 设计 过 程 


(1) 编写 index.php 用 户 登 录 页 面 ， 创 建 表单 ， 在 表单 中 添加 用 户 名 文本 域 、 密 码 域 、 验 证 码 文本 域 以 及 
保存 随机 数 的 隐藏 域 。 

(2) 为 了 提高 网 站 的 安全 性 和 人 性 化 ， 在 用 户 登录 或 注册 表单 中 的 数据 提交 给 服务 器 之 前 ， 需 要 对 其 进行 
合理 性 验证 。 本 实例 应 用 JS 文件 夹 下 的 funjs 脚本 文件 在 客户 端 对 表单 提交 数据 进行 验证 ， 这 样 可 以 降低 服务 
器 负载 ， 在 实际 项 目 开 发 中 ， 对 一 些 安全 性 要 求 较 高 的 模块 ， 建 议 采 用 客户 端 和 服务 端 双重 验证 ， 这 样 既 可 以 
为 用 户 操作 带 来 方便 ， 还 可 以 保证 系统 的 安全 。 

(3) 编写 JavaScript 脚本 生成 4 位 随机 数 ， 并 且 在 用 户 单 击 “ 看 不 清 ”链接 时 ， 设 法 在 不 刷新 页 面 的 情况 
下 动态 改变 这 4 位 随机 数 的 值 。 本 实例 通过 Math 对 象 的 random0 方 法 产生 4 位 随机 数 ， 然 后 通过 自 定义 方法 
code_10 动 态 更 改 验 证 码 的 值 。 实 现 该 过 程 的 关键 代码 如 下 : 


<script language="javascript"> 

var numl=Math.round(Math.random()*10000000); 

var num=num]1.toString().substr(0,4); // 产 生 4 位 随机 数 

document write("<img name=codeimg4 sre=xym.php?num="+num.substr(0,1)+">"); 

document write("<img name=codeimg5 sre='xym.php?num="+num.substr(1,1)+">"); 

document write("<img name=codeimg6 sre=xym.php?num="+num.substr(2,1)+">"); 

document write("<img name=codeimg7 sre=xym.php?num="+num.substr(3,1)+">"); 

form login.xyml .value=num:; 

function code_10{ // 通 过 该 方法 动态 改变 验证 码 的 值 

var num1=Math.round(Math.random()*10000000); 
var num=numl .toString().substr(0,4); 
document.codeimg4.sre="xym.php?num="+num.substr(0,1); 
document.codeimgS.sre="xym. php?num="+num.substr(1,1); 
document.codeimg6.sre="xym.phpInum=" me 
document.codeimg7.sre="xym.php?num="+nun.substr(3. 
form_login.xyml.value=num; 将 下 证 到 的 信 丰 给 隐藏 

} 

</script> 

(4) 创建 xym.php 文件 ， 采 用 PHP 文件 操作 函数 将 图 片 以 二 进 制 的 形式 输出 到 浏览 器 ， 这 样 可 以 有 效 地 


提高 静态 页 面 与 动态 页 面 之 间 的 交互 性 ， 其 代码 如 下 : 
Snum=$_GET[num]; /| 接收 GET 方法 传递 过 来 的 参数 


Saddress="images/code/". $num.".gif"; /获取 图 片 路 径 
Sfp=fopen($address,"r"): /打开 图 片 文件 
echo fread($fp,filesize(Saddress)); // 将 图 片 文件 读 取 到 浏览 器 
felose(${p); 1/ 关闭 打开 的 文件 句柄 
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心 法 领悟 276: PHP 标记 的 特性 。 

如 果 在 PHP 页 面 中 ， 不 仅 包含 PHP 代码 ， 而 且 包含 其 他 语言 代码 ， 如 JavaScript、CSS 或 HTML 等 ， 需 要 
书写 完整 的 PHP 代码 块 标记 ， 即 “<?php” 与 “?>” 都 要 写 ， 如 果 页 面 代码 完全 由 PHP 构成 ， 则 建议 只 写 开始 
标记 ， 不 写 结束 标记 ， 这 样 可 以 防止 恶意 用 户 通过 非法 注入 等 手段 在 页 面 代码 后 注入 恶意 代码 。 


枯 高 级 | 
实例 277 吉林; 雪夫 
实例 说 明 


验证 码 不 但 可 以 使 用 数字 图 像 来 完成 ， 而 且 可 以 使 用 中 文 图 像 来 完成 。 为 了 防止 用 户 通过 恶意 程序 登录 站 
点 ， 提 高 网 站 的 安全 性 ， 在 本 实例 中 将 介绍 如 何 通 过 中 文 图 像 来 生成 验证 码 ， 运 行 结果 如 图 6.8 所 示 。 
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图 6.8 ”中文 图 像 验 证 码 


图 关键 技术 


开发 中 文 图 像 验证 码 ， 首 先 应 该 确定 所 使 用 的 文字 并 且 将 文字 制作 成 图 片 ， 以 数字 进行 命名 。 然 后 将 所 使 
用 的 文字 定义 到 数组 中 。 最 后 计算 出 数组 中 元 素 的 长 度 值 ， 并 应 用 rand0 函 数 从 这 个 长 度 值 中 随机 取 值 ， 根 据 
随机 取 值 输出 对 应 的 中 文 图 像 ， 即 验证 码 ， 其 关键 代码 如 下 : 


<?php 
$str = amray ("大 ", "更 "" 创 ", "天 ", " 科 ", " 客 "," 博 "," 技 ", " 立 ", "新 " ); /定义 中 文字 符 串 的 数组 
$word = count ( $str ); 1/ 计算 出 数组 中 元 素 个 数 
for($i=0; $i< 4; $i++) { /| 执行 for 循环， 以 数组 中 元 素 个 数 为 范围 随机 取出 4 个 值 
Snum = rand ( 0, $word - 1 ); /$word=$word*2-1 // 随 机 取 值 
/输出 随机 取出 的 4 个 值 对 应 的 中 文 图 片 
Simg = $img . "<img sre=" images/checkcode/" . $num . ".gif width=16 height="16>"; /显示 随机 图 片 
Spic = $pic . $str [$num]; // 将 图 片 转换 成 数组 中 的 文字 
} 
力 设计 过 程 


(1) 编写 index.php 用 户 登 录 页 面 ， 创 建 表单 ， 在 表单 中 添加 用 户 名 文本 域 、 密 码 域 、 验 证 码 文本 域 以 及 
保存 随机 数 的 隐藏 域 。 

(2) 在 index.php 页 面 中 编写 PHP 脚本 ， 定 义 验证 码 所 使 用 的 中 文字 符 串 并 生成 验证 码 ， 其 关键 代码 请 参 
考 本 实例 的 关键 技术 。 

(3) 本 实例 中 沿用 实例 276 中 对 表单 中 元 素 进行 验证 的 方法 ，funjjs 脚本 文件 同样 存储 于 js 文件 夹 中 。 

(4) 创建 checkuser.php 文件 ， 完 成 对 用 户 提交 的 登录 信息 的 验证 。 


国 秘笈 心 法 


心 法 领悟 277: 如 何 计算 数组 中 元 素 的 数目 。 

在 本 实例 中 , 应 用 count 0 函数 计算 数组 中 元 素 的 数目 。 注意 ,count0 函 数 只 适用 于 计算 数组 中 元 素 的 个 数 ， 
如 果 将 其 应 用 到 其 他 类 型 的 数据 中 ， 那 么 返回 值 只 有 一 个 单元 。 如 果 要 计算 字符 串 的 长 度 ， 那 么 要 使 用 strlen0 
函数 ， 切 记 strlen0 函 数 不 可 对 数组 元 素 进 行 操作 ， 虽 然 不 返回 错误 信息 ， 但 是 返回 的 结果 是 不 准确 的 。 


高 级 
起 味 指教 : 宽 本 让 太 


实例 278 


力 实例 说 明 


上 传 图 片 是 一 个 比较 常见 的 功能 ， 但 是 在 输出 上 传 图 片 时 可 能 会 遇 到 一 些 问题 ， 由 于 上 传 图 片 的 大 小 没有 
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固定 ， 从 而 导致 图 片 在 输出 时 变形 ， 这 是 一 个 很 让 人 伤 脑筋 的 问题 。 如 果 在 上 传 图 片 时 直接 将 其 生成 一 个 固定 
大 小 的 缩 略图 ， 并 同时 保存 上 传 的 原始 图 片 ， 那 么 在 输出 时 就 不 会 有 任何 问题 。 

在 本 实例 中 就 实现 了 这 样 一 个 功能 ， 即 在 将 图 片上 传 到 服务 器 的 同时 生成 图 片 的 缩 略图 ， 浏 览 的 是 图 片 的 
缩 略 图 ， 而 如 果 要 下 载 ， 则 下 载 的 仍 是 原始 图 片 。 本 实例 的 运行 效果 如 图 6.9 所 示 。 


EE om Es ee 
7 图 Fe ks 
Ph 入 = | 
/= 
En 图 C7 


图 6.9 缩 略图 艺术 库 


图 关键 技术 


在 本 实例 中 ， 有关 多 图 片 的 任意 上 传 和 图 片 的 分 页 输出 不 再 是 讲解 的 重点 ， 如 果 读 者 要 了 解 这 方面 的 内 容 ， 
请 参考 本 书 第 4 章 的 内 容 。 

本 实例 重点 讲解 的 是 如 何 生成 图 片 的 缩 略图 ， 并 且 为 缩 略图 添加 水 印 ， 其 原理 如 下 : 

(1) 通过 getimagesize0 函 数 获取 上 传 图 片 的 信息 ， 包 括 大 小 、 类 型 等 ， 并 根据 其 类 型 ， 新 建 一 个 对 应 类 型 
的 图 像 。 

getimagesize0 〇 函数 获取 指定 图 像 的 大 小 ， 语 法 如 下 : 

array getimagesize ( string filename [, array &imageinfo] ) 

getimagesize0 函 数 将 测定 任何 GIF、JPG、PNG、SWF、SWC、 PSD、TIFF、BMP、 IFF、JP2、JPX、JB2、 
JPC、XBM 或 者 WBMP 图 像 文件 的 大 小 ， 并 返回 图 像 的 尺寸 以 及 文件 类 型 和 一 个 可 以 用 于 普通 HTML 文件 
中 <IMG> 标记 中 的 height/width 文本 字符 串 ， 其 返回 值 是 一 个 具有 4 个 单元 的 数组 : 

回 索引 0 包含 图 像 宽度 的 像素 值 。 

回 索引 1 包含 图 像 高 度 的 像素 值 。 

索引 2 是 图 像 类 型 的 标记 : 1 = GIF，2 = JPG, 3=PNG, 4=SWF, 5=PSD, 6=BMP, 7= TIFF(intel 

byte order), 8 = TIFF(motorola byte order), 9 = JPC, 10= JP2, 11= JPX, 12=JB2, 13 = SWC, 14 = IFF， 
15=WBMP, 16=XBM。 

回 ”索引 3 是 文本 字符 串 ， 内 容 为 height="yyy" width="xxx"， 可 直接 用 于 IMG 标记 。 

如 果 参 数 filename 指定 的 图 像 不 存在 或 者 不 是 有 效 的 图 像 ， 将 返回 FALSE 并 产生 一 条 E_WARNING 级 
的 错误 。 

(2) 对 上 传 图 片 的 大 小 与 指定 缩 略 图 的 大 小 进行 比较 ， 看 其 是 否 需要 创建 缩 略 图 。 

(3) 根据 判断 结果 应 用 imagecopyresampled0O 函 数 重新 生成 新 的 图 像 。 

imagecopyresampled(O) 函 数 从 原 图 像 中 采样 ， 复 制 部 分 图 像 重 新 生成 图 像 ， 语 法 如 下 : 


bool imagecopyresampled ( resource dst_image. resource src_image. int dst_x. int dst_y. int src_x. int src_y. int dst_w. int dst_h., int sre_w, int sre_h ) 


imagecopyresampled0 函 数 将 一 幅 图 像 中 的 一 块 正方 形 区 域 复制 到 另 一 个 图 像 中 ， 平 滑 地 插入 像素 值 ， 在 减 
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小 图 像 大 小 的 同时 ， 仍 然 保持 了 极 大 的 清晰 度 。 

参数 说 明 : 

dst_image: 目标 图 像 标 识 符 ; 

src_image: 源 图 像 标识 符 。 

如 果 源 图 像 和 目标 图 像 的 宽度 和 高 度 不 同 ， 则 会 进行 相应 的 图 像 收 缩 和 拉 伸 。 坐 标 指 的 是 左上 角 。 本 函数 
可 用 来 在 同一 幅 图 内 部 复制 〈 如 果 dst image 和 src_image 相同 的 话 ) 区 域 ， 但 如 果 区 域 交 迭 的 话 则 结果 不 可 
预知 。 

如 果 成 功 则 返回 TRUE， 失 败 则 返回 FALSE。 


< 注意 : 本 函数 需要 GD 库 2.0.1 版 或 者 更 高 版 本 的 支持 。 


(4) 为 重新 生成 的 图 像 添加 水 印 ， 可 以 选择 文字 水 印 或 者 图 像 水 印 。 

添加 文字 水 印 应 用 ImageTTFText0 函 数 ， 如 果 页 面 使 用 的 不 是 UTF-8 编码 ， 那 么 还 要 对 水 印 文字 的 编码 格 
式 进行 转换 ， 因 为 ImageTTFTextO 函 数 只 支持 UTF-8 编码 。 

添加 图 像 水 印 应 用 imagecopy0 函 数 ， 完 成 对 图 像 的 复制 操作 。 
图 设计 过 程 

缩 略 图 艺术 库 沿用 了 第 4 章 中 实例 229 通过 header0 函 数 进行 下 载 的 内 容 , 在 此 基础 上 增加 上 传 图 片 生成 缩 
略图 的 功能 ， 有 关上 传 和 下 载 这 里 不 再 袭 述 。 

(1) 在 上 传 文件 的 处 理 页 index_ok.php 中 ， 包 含 了 一 个 thumbnail.php 文件 ;重新 定义 上 传 文件 的 类 型 ， 
并 重新 指定 上 传 文件 的 存储 位 置 ， 定 义 原始 文件 存储 文件 夹 和 缩 略 图 存储 文件 夹 ， 在 通过 move_uploaded_file() 


函数 完成 文件 的 上 传 操作 后 ， 调 用 thumbnail.php 文件 中 包含 的 方法 makethumb0 将 上 传 的 图 片 生成 缩 略 图 ， 并 


添加 文字 水 印 。 这 是 在 index_ok.php 文件 中 所 做 的 处 理 ， 其 关键 代码 如 下 : 
<?php 
header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
include "conn/conn.php"; 
include "thumbnail.php"; 
if($_POST [files] !="") { 
Sdata = date ("Y-m-d H:nmx:s" ); 


function check($var) { // 验 证 数组 的 返回 值 是 否 为 空 
retum ($var != ""); 
} 
Sfiles = array_filter ( $_POST ["files"], "check" ); // 去 除数 组 中 的 空 值 
Sarray = array_filter ( $_FILES ["picture"] ["name"], "check" ): // 去 除数 组 中 的 空 值 
foreach ( $array as $key => $value ) { 1/ 循环 读 取 数组 中 的 数据 
$types = strtolower ( strstr ( $value, ", ) ); /截取 上 传 文件 的 后 缀 
if ($types — "jpg" || $types 一 "gif" | $types — ".png") { 1/ 判断 上 传 文件 的 后 缀 是 否 符合 要 求 
Sthumbnail = tbhumbnail/: 
iginal/: 
$file_ name =time () . $key . strtolower ( strstr ( $value. "." ) ); /定义 上 传 文件 名 称 
Spath = $original . $file_name: /定义 原始 文件 的 存储 位 置 
$path_thumbnail = $thumbnail . $file_name; // 定 义 缩 略 图 的 存储 位 置 
move_uploaded file ($_FILES ["picture"] ["tmp_name"] [$key]. $path ): 1/ 执行 上 传 操作 
makethumb ( $path, $path_thumbnail, "200", "200", "100", "www.mrbeed.com" ); // 生 成 缩 略图 


Squery = "insert into tb_up_file (file_test.path_thumbnail.data.file_name) values (‘$path','S$path_thumbnail''Sdata','$files[Skey])"; 
$result = mysql_ query ( $query ); 


}else{ 
echo "上 传 文件 " . $value . "类 型 不 正确 !"; 


"<script>alert(' 图 片上 传 成 功 ): window.location href='index.html';</script>"; 


see 中 


(2) 编写 thumbnailphp 文件 ， 定 义 makethumb(0 方 法 ， 完 成 缩 略 图 的 生成 和 水 印 的 添加 操作 。 自 定义 方法 
makethumb0 的 语法 如 下 : 
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makethumb($srcFile, $dstFile, $dstW, $dstH., $rate = 100, $markwords =null, $markimage = null) {} 
参数 说 明 : 

SsrcFile: 图 片 文件 名 。 

$dstFile: 另存 文件 名 。 

Smarkwords: 水 印 文字 。 

$markimage: 水 印 图 片 。 

$dstW: 图 片 保存 宽度 。 

$dstH: 图 片 保存 高 度 。 

Srate: 图 片 保存 品质 ， 默 认 值 为 100。 

有 关 thumbnail.php 文件 的 完成 代码 请 参考 本 书 光盘 。 


心 法 领悟 278: 定义 缩 略图 的 好 处 。 
运用 缩 略 图 技术 可 解决 图 片 输出 时 的 变形 问题 ， 无 论 是 否定 义 输出 图 片 的 大 小 ， 它 都 将 以 一 个 相同 的 尺寸 
进行 输出 ， 使 页 面 更 加 规范 、 美 观 ， 同 时 也 避免 了 输出 图 片 的 拉 伸 变 形 。 
高 级 : 
趣味 指数 ， lodedole, 


实例 279 


图 实例 说 明 


EXIF 信息 是 指 由 数码 相机 在 拍摄 过 程 中 采集 一 系列 的 信息 ， 然 后 把 信息 放置 在 JPEG/TIFF 文件 的 头 部 ， 
也 就 是 说 EXIF 信息 是 镶嵌 在 JPEG/TIFF 图 像 文件 格式 内 的 一 组 拍摄 参数 ， 主 要 包括 摄影 时 的 光圈 、 快 门 、 
ISO、 日 期 时 间 等 各 种 与 当时 摄影 条 件 相关 的 讯息 ， 以 及 相机 品牌 型 号 、 色 彩 编码 、 拍 摄 时 录制 的 声音 和 全 球 定 
位 系统 (GPS) 等 信息 。 既 然 在 EXIF 中 包含 了 如 此 详细 和 完整 的 信息 ， 那 么 在 PHP 中 应 该 如 何 获取 到 这 些 信 
息 呢 ?这 就 是 本 实例 将 要 介绍 的 技术 一 一 获取 并 输出 图 像 的 EXIF 信息 ， 其 运行 结果 如 图 6.10 所 示 。 


ET 朗科 如 :1279329073L jpt 
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et 002 玫 4 
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各 ;17T9TCCDSL jpg 文件 各 42752255131 jpg 
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图 6.10 提取 图 像 的 EXIF 信息 


图 关键 技术 


在 PHP 中 ,获取 EXIF 信息 应 用 的 是 EXIF 函数 库 中 的 函数 。 首 先 ， 应 该 确定 EXIF 函数 是 否 已 经 加 载 ， 在 
php.ini 文件 中 查看 extension=php_exif.dll 前 是 否 有 分 号 “;”， 如 果 有 则 说 明 未 加 载 ， 要 将 分 号 去 掉 。 
同时 还 要 注意 extension=php_exif.dll 项 的 存储 位 置 ， 必 须 放 置 在 extension=php_mbstring.dll 项 之 后 ， 否 则 
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EXIF 函数 是 不 被 支持 的 。 设 置 完成 后 保存 php.ini 文件 ， 并 重新 启动 Apache 服务 器 。 在 本 实例 中 ， 具 体 应 用 的 
是 EXIF 函数 库 中 的 exif read_data0 函 数 ， 获 取 图 像 的 EXIF 信息 。 


exif read _data0) 函 数 从 JPEG 或 TIFF 文件 中 读 取 EXIF 头 信息 ， 其 语法 如 下 : 
array exif read data ( string filename [, string sections [. boolarmays [, bool thumbnail]]] ) 


参数 说 明 : 

filename: 被 读 取 的 图 像 文件 名 ， 不 可 以 是 URL。 

sections: 定义 存在 于 文件 中 的 逗号 分 隔 的 区 段 列表 ， 用 来 产生 结果 数组 。 如 果 未 找到 所 请 求 的 区 段 则 返回 
值 为 FALSE。 所 包含 的 区 段 如 表 6.1 所 示 。 


表 6.1 exif_read_data() 函 数 中 参数 sections 包含 的 区 段 


区 段 名 称 包含 内 容 、 说 明 

FILE FileName、FileSize、FileDateTime、SectionsFound 

html、Width、Height、IsColor， 可 能 有 更 多 其 他 的 。Height 和 Width 是 用 和 getimagesize( 一 样 的 方 
COMPUTED ”| 法 计算 的 ， 因 此 它们 的 值 不 能 是 任何 返回 的 头 信息 的 部 分 ，html 是 一 个 height/width 文本 字符 串 ， 可 
以 用 于 普通 的 HTML 中 

ANY TAG 任何 包含 有 标记 的 信息 ， 如 IFD0、EXIF 等 

IFD0 所 有 IFD0 的 标记 数据 。 在 标准 的 图 像 文件 中 包含 了 图 像 大 小 及 其 他 

THUMBNAIL | 如 果 有 第 二 个 FD， 文 件 应 该 包含 有 缩 略 图 。 所 有 嵌入 缩 略图 的 标记 信息 都 存储 在 本 
COMMENT JPEG 图 像 的 注释 头 信息 

EXIF EXIF 区 段 是 IFD0 的 子 区 ， 包 含有 图 像 的 更 多 详细 信息 。 多 数 内 容 都 是 与 数码 相机 相关 的 
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arrays: 指定 是 否 每 个 区 段 都 成 为 一 个 数组 。sections COMPUTED、THUMBNAIL 和 COMMENT 区 段 总 
是 成 为 数组 ， 因 为 它们 里 面包 含 的 名 字 和 其 他 区 段 冲突 。 

thumbnail， 如 果 该 值 为 TRUE， 读 取 缩 略图 本 身 ， 和 否则 只 读 取 标 记 数 据 。 

exif read_data() 函 数 的 返回 值 是 一 个 关联 数组 , 键 名 是 头 信息 名 , 值 是 与 其 对 应 的 数据 。 如 果 没 有 可 供 返 
的 数据 ， 将 返回 FALSE。 


图 设计 过 程 
本 实例 沿用 缩 略图 艺术 库 中 的 内 容 ， 实 现 多 图 片 的 上 传 和 分 页 输出 ， 并 且 为 上 传 的 图 片 生成 缩 略图 。 在 分 
页 输出 上 传 图 片 时 ， 运 行 自 定义 函数 GetImageInfo0 获 取 图 片 的 EXIF 信息 ， 并 且 输 出 图 片 的 名 称 和 拍摄 时 间 。 


(1) 在 index.php 页 面 中 ,实现 上 传 图 片 的 分 页 输出 ,并 且 包 含 exif.php 文 件 ,调用 自 定义 函数 GetImageInfo() 
获取 图 片 的 EXIF 信息 ， 输 出 图 片 的 名 称 和 拍摄 时 间 ， 其 关键 代码 如 下 : 


回 


<?php 

include "exif.php"; /包含 exifphp 文件 
Spic=GetImageInfo($myrow[file_test]): /调用 getimageinfo0 方 法 ， 获 取 原 始 图 片 的 EXIF 信息 
echo "文件 名 : ".$pic[ 文 件 名 ]."<br>": /输出 图 片 名 称 

echo " 拍摄 时 间 : ".$pic[' 拍 摄 时 间 : /输出 拍摄 时 间 


(2) 创建 exifphp 文件 。 编 写 自 定义 函数 GettmageInfo0， 应 用 exif read_data0) 函 数 获 取 指定 图 片 的 EXIF 


信息 ， 其 关键 代码 如 下 : 

<Iphp 

function GetImageInfo($img) { 
Simgtype = array ("", "GIF", "JPG", "PNG", "SWF", "PSD", "BMP" ): 
$Orientation = array ("", "top left side". "top right side". "bottom right side” ): 
$ResolutionUnit = array ("", "", "英寸 ", "厘米 " ): 
Sexif =exif read_data ( Simg. "IFDO" ); 
if (Sexif =— false) { 

Snew_img_info =array ("文件 信息 " => "没有 图 片 EXIF 信息 " ): 
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}else{ 
Sexif = exif read_data ( Simg. 0, true ): 
Snew_img_info =array ("文件 名 " => Sexif [FILE] [FileName], "时 间 截 " => date ( "Y-m-d H:i:s", Sexif [FILE] [FileDateTime] ); 
} 
retum $new_img_info; 
} 


有 关 本 实例 的 其 他 内 容 ， 由 于 篇 幅 所 限 ， 请 参考 本 书 光盘 ， 这 里 不 再 袭 述 。 


心 法 领悟 279: 通过 表单 中 的 隐藏 域 控制 上 传 文件 的 大 小 。 

在 对 上 传 的 文件 进行 判断 时 ， 如 果 应 用 $_FILES['picture']['error] 对 上 传 信息 进行 判断 ， 当 其 返回 值 为 2 时 ， 
说 明 上 传 文件 的 大 小 超出 表单 中 约定 的 范围 ， 而 表单 中 的 这 个 约定 值 是 通过 隐藏 域 MAX_FILE_SIZE 的 值 来 控 
制 的 。 在 设置 这 个 隐藏 域 时 ， 必 须 将 隐藏 域 放置 在 文件 域 之 前 ， 否 则 不 起 作用 。 


6.2 控制、 显示 图 片 特性 


在 网 页 中 适当 地 应 用 一 些 动态 图 片 特效 ， 不 仅 可 以 使 整个 页 面具 有 更 大 的 视觉 冲击 力 ， 还 可 以 使 页 面具 有 
温 声 感 ， 最 终 达 到 提高 网 站 访问 量 的 目的 。 


实例 280 


力 实例 说 明 


为 了 合理 利用 网 页 空间 ， 在 网 页 设计 时 会 缩小 某 些 图 片 的 实际 尺寸 ， 但 这 样 可 能 导致 浏览 者 看 不 清 图 片 的 
内 容 ， 为 了 解决 上 述 问题 ， 可 以 通过 鼠标 滑轮 改变 图 片 的 大 小 。 运 行 本 实例 ， 将 显示 如 图 6.11 所 示 的 页 面 ， 将 
鼠标 指针 放 到 图 片上 ， 通 过 滚动 鼠标 滑轮 即 可 改变 图 片 的 大 小 。 


图 6.11 通过 鼠标 滑轮 控制 图 片 大 小 


力 关键 技术 


本 实例 主要 通过 调用 自 定义 函数 change_img10 和 自 定义 函数 change_img20 实 现 图片 的 大 小 改变 ， 并 通过 
onmousewheel 事件 调用 这 两 个 函数 。 
onmousewheel 事件 用 于 调用 handlerText 所 代表 的 Javascript 方法 ， 语 法 如 下 : 


onmousewheel="handlerText" 
力 设计 过 程 
(1) 在 页 面 中 插入 两 幅 图 片 ， 并 通过 这 两 幅 图 片 的 onmousewheel 事件 调用 函数 change img10 和 函数 
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change_img20， 代 码 如 下 : 
img id"img" sre="images/image gif' width="60" height="60" onmousewheel="change_ img1(this)"/> 
<img id="img" ste="imagesimage.gif" width="60" height="60" onmousewheel="change_ img2(this)"/> 
(2) 编写 函数 change_img10 和 函数 change img20 改 变 图 片 的 大 小 ， 代 码 如 下 : 
<script language—"javascript"> 
function change imgl(x) { 
x width= x.width+10; 
if(x.width=—1000|x.height—1000) { 
x.width=60; 
x.height=60; 
s } 
fanction change_img2(x) { 
x.width= x.width-10; 
x height=x height-10; 
ix.width 一 0|height 一 0) { 
x.width=60; 
x.height=60; 
b 
} 
</script> 


心 法 领悟 280: 图 片 特 效 的 扩展 。 


本 实例 介绍 的 是 通过 鼠标 滑轮 控制 图 片 的 大 小 ， 依 据 此 原理 ， 还 可 以 实现 图 片 放大 镜 的 功能 ， 通 过 倍数 来 
控制 图 片 的 大 小 。 


中 级 
图 实例 说 明 


在 用 户 登 录 页 面 或 留言 发 表 页 面 经 常会 看 到 验证 码 的 身影 ， 通 过 这 项 技术 可 以 大 幅度 提高 网 站 的 安全 性 。 
运行 本 实例 ， 可 以 发 现在 如 图 6.12 所 示 的 登录 页 面 中 随机 产生 了 4 位 数字 (6191) ， 每 次 刷新 页 面 这 4 位 数字 
都 会 发 生 改变 ， 用 户 登 录 时 必须 输入 这 4 位 数字 ， 这 样 可 以 防止 用 户 通过 恶意 程序 来 试探 登录 密码 的 值 从 而 非 
法 登录 网 站 。 


图 6.12 显示 随机 图 像 


图 关键 技术 


应 用 PHP 的 随机 函数 mt rand0 生 成 随机 验证 码 ,根据 随机 验证 码 的 值 读 取 对 应 的 数字 图 片 ， 生 成 验证 码 
图 像 。 
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mt_rand0 函 数 用 于 产生 min 和 max 之 间 的 随机 数 ， 语 法 如 下 : 


int mt_rand([int min].[int max]) 
参数 min 和 max 指定 随机 数 的 取 值 范围 。 
在 读 取 生 成 的 随机 验证 码 时 ， 应 用 到 for 语句 和 substr0 函 数 对 验证 码 的 值 进行 读 取 ， 根 据 读 取 的 值 定义 输 
出 的 数字 图 像 ， 其 关键 代码 如 下 : 

i Snum = intval ( mt_rand ( 1000. 9999 ) ); /| 生成 随机 验证 码 

for($i=0; $1< 4; $i++) { // 循 环 读 取 验 证 码 

echo "<img sre=images/code/" . substr ( strval (Snum ), Si 1 ) .".gif>"; _// 输 出 数字 图 像 
} 


图 设计 过 程 
(1) 创建 用 户 登录 页 面 ， 添 加 用 户 登录 表单 。 
(2) 创建 JavaScript 脚本 ， 定 义 chkuserinput0 方 法 对 表单 中 提交 的 数据 进行 验证 。 
<script language="javascript"> 
function chkuserinput(form){ 


if(formusemame.value—""){ 
alert(" 请 输入 用 户 名 !" ); 


} 

if(form.userpwd.value—"") { 
alert(" 请 输入 用 户 密码 !"); 
form.userpwd.select(); 
return(false); 

} 

iflform.yz.value—""){ 
alert(" 请 输入 验证 码 !"); 
form.yz.select0: 
Teturn(false): 


retum(true); 
} 
</script> 


(3) 编写 PHP 脚本， 通过 mt_rand0 函 数 生成 4 位 随机 验证 码 ， 并 输出 4 位 随机 验证 码 对 应 的 图 片 。 
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心 法 领悟 281: mt_rand0 函 数 的 应 用 。 
通过 mt_rand0 函 数 获取 随机 数 不 但 可 以 用 于 验证 码 的 生成 ， 还 可 以 应 用 到 随机 抽奖 或 者 随机 抽取 考题 的 程 
序 中 。 其 应 用 的 原理 都 是 相同 的 ， 如 果 读 者 感 兴趣 可 以 亲自 体验 一 下 。 


实例 282 趣味 指数 : 请 庚 请 家 ， 


图 实例 说 明 
在 开发 Web 项 目 中 ， 经 常 需要 准确 地 获取 图 像 的 尺寸 ， 以 达到 精确 定位 MR 
的 目的 。 运 行 本 实例 ， 将 显示 如 图 6.13 所 示 的 页 面 ， 生 成 该 页 面 的 同时 程序 明日 科技 
会 计算 出 页 面 中 图 像 的 高 度 和 宽度 ， 以 便于 开发 人 员 实现 对 图 片 的 定位 。 [| 
图 关键 技术 图 6.13 获取 图 像 的 实际 尺寸 


PHP 中 获取 图 像 的 大 小 应 用 getimagesize0 函 数 。 该 函数 用 于 获取 图 片 的 实际 尺寸 ， 其 语法 如 下 : 


379 


PHP 开发 实例 大 全 (基础 卷 ) 
array getimagesize ( string filename [, array imageinfo]) 
getimagesize0 函 数 返回 一 个 具有 4 个 单元 的 数组 ， 如 下 所 示 : 
索引 0: 图 像 宽度 的 像素 值 。 
索引 1: 图 像 高 度 的 像素 值 。 


索引 2: 图 像 类 型 的 标记 : 1 = GIF, 2= JPG, 3 = PNG, 4= SWF, 5=PSD, 6= BMP, 7=TIFF(intel byte 
order), 8=TIFF(motorola byte order), 9=JPC, 10=JP2, 11=JPX, 12=JB2, 13=SWC, 14=IFF, 
15=WBMP，16=XBM。 

回 


索引 3: 文本 字符 串 ， 内 容 为 height="yyy" width="xxx"， 可 直接 用 于 <img> 标记 。 
图 设计 过 程 
本 实例 主要 利用 getimagesize(O) 函 数 获 取 图 片 的 实际 尺寸 ， 代 码 如 下 : 
SeaoerinCuaieiatipey 
图 秘笈 心 法 
心 法 领悟 282: getimagesize() 函 数 的 妙用 。 


虽然 本 实例 只 是 对 getimagesize0 函 数 的 语法 、 基 本 功能 进行 了 讲解 ， 读 者 也 许 并 未 发 现 它 的 特殊 之 处 ， 功 


能 也 不 过 如 此 ， 但 是 当 你 再 次 回顾 前 面 讲解 的 缩 略图 艺术 库 和 提取 图 像 的 EXIF 信息 两 个 实例 时 ， 就 会 发 现 这 
个 函数 的 重要 性 。 


中 级 .| 
实例 283 起 味 指数 : 良友 朗 安 
实例 说 明 


在 图 片 信息 较 多 的 网 页 中 ， 通 过 图 像 手 动 播放 的 方式 显示 图 片 不 仅 可 以 节省 页 面 空间 ， 而 且 可 以 使 浏览 者 
自主 选择 喜爱 的 图 片 进行 显 示 。 运 行 本 实例 ， 浏 览 者 可 以 通过 如 图 6.14 所 示 的 “ 左 ” 和 “ 右 ” 文 字 超 链接 浏览 
所 有 图 片 。 


明日 图 书 在 线 


从 设 为 首页 加 收 羡 本 站 岛 联系 我 们 


图 6.14 获取 图 像 的 实际 尺寸 
图 关键 技术 


本 实例 主要 应 用 onclick0 事 件 调用 JavaScript 脚本 中 的 方法 ， 完 成 图 像 的 手动 播放 操作 ， 在 JavaScript 中 定 
义 了 toleft0 和 toright0 两 个 方法 ， 其 代码 如 下 : 


<script language="javascript"> 
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fanction tolefO{ 
if(demol.offsetWidth-demo.scrollLeft<=0) 
demo.scrollLeft=0 
else 
demo.scrollLefi=demo.scrollLeft+10; 
} 
function torightO{ 
if(demol.offsetWidth-demo.scrollLeft<=0) 
demo.scrollLeft=0 
else 
demo serollLeft-demo serollLeft-10: 


</script> 
设计 过 程 
(1) 设计 网 页 的 页 面 ， 定 义 <div> 标 签 和 插入 手动 播放 的 图 像 。 


(2) 编程 控制 图 像 播 放 的 JavaScript 脚本 。 
(3) 在 超 链 接 中 通过 onclick0 事 件 完成 对 JavaScript 脚本 中 方法 的 调用 ， 其 关键 代码 如 下 : 


<td width="100"><div align="left"><a href="#" onclick="toleft0"> 左 </a></div></td> 
<td width="100"><div align="right"><a href="#" onclick="torightO"> 右 </a></div></td> 
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心 法 领悟 283， 图 像 手动 播放 的 好 处 。 
虽然 图 像 的 手动 播放 没有 图 像 自动 播放 灵活 ， 但 是 手动 播放 的 最 大 优点 是 可 以 定位 网 页 中 播放 的 内 容 ， 而 
自动 播放 却 不 能 对 其 进行 定位 ， 只 能 不 停 地 循环 播放 。 
人 ££、 ; 
中 级 | 
趣味 指数 : 请 请 请 穴 | 


实例 284 


图 实例 说 明 


图 像 的 自动 播放 不 仅 可 以 增添 Web 页 面 的 动态 效果 ， 而 且 可 以 节省 网 页 空间 ， 有 效 地 保证 在 有 限 的 页 面 中 
显示 更 多 的 图 片 。 运 行 本 实例 ， 如 图 6.15 所 示 ， 图 像 将 从 右 向 左 自动 播放 。 


图 6.15 图 像 的 自动 播放 


图 关键 技术 


本 实例 主要 应 用 setInterval0 函 数 ， 在 指定 的 时 间 间 隔 time 内 调用 函数 方法 ， 完 成 图 像 的 自动 播放 操作 。 
setInterval0 函 数 的 语法 如 下 : 


setInterval(fiunction.time) 
图 设计 过 程 
(1) 设计 网 页 的 页 面 ， 定 义 <div> 标 签 和 插入 手动 播放 的 图 像 ， 其 代码 如 下 : 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


<div id="demo" style="OVERFLOW: hidden: WIDTH: 740px: HEIGHT: 176px" > 
<table cellspacing="0" cellpadding="0" align="center" border="0"> 
<tr> 
<td id-"demol">&nbsp: 
<img height="175" sre="images/1.bmp" width="143" border="0" />&nbsp: 
<htd> 
<td id="demo2"></td> 


(2) 编程 控制 图 像 自 动 播放 的 JavaScript 脚本 ， 并 应 用 setInterval0 函 数 完成 对 Marquee0 方 法 的 调用 ， 其 
代码 如 下 : 


<SCRIPT language="javascript"> 

var speed=20 

demo2 innerHTMIL=demol innerHTML 

function MarqueeO{ 

if(demol .offsetWidth-demo.serollLeft<=0) 
demo.scrollLeft=0 


else 
demo.scrollLeft++ 


var MyMar=setInterval(Marquee.speed) 
demo.onmouscover=function() {clearInterval(MyMar)} 
demo.onmouseout=function0) {MyMar=setInterval(Marquee.speed)} 
</SCRIPT> 


国 秘笈 心 法 
心 法 领悟 284: 图 像 自动 播放 的 控制 。 


对 于 图 像 的 自动 播放 ， 我 们 可 以 不 用 了 解 其 具体 是 如 何 运作 的 ， 只 需 明确 它 调用 的 方法 ， 定 义 <div> 标 签 的 
ID 以 及 传递 正确 的 时 间 间 隔 ， 即 可 完成 图 像 的 自动 播放 功能 。 


于 
a 片 的 大 小 中 级 | 
实例 285 趣味 指数 : 页 页 页 窜 | 

图 实例 说 明 


图 像 大 小 的 调整 对 于 专业 的 美工 或 者 网 页 设计 者 来 说 不 算 什么 ， 但 是 对 于 程序 员 来 说 ， 特 别 是 不 善于 处 理 
图 片 的 程序 员 来 说 ， 是 一 个 非常 头疼 的 问题 。 虽 说 图 片 处 理 不 在 程序 员 的 工作 范围 之 内 ， 但 是 有 些小 问题 还 是 
自己 解决 更 好 。 在 本 实例 中 向 程序 员 介绍 一 种 方法 ， 通 过 我 们 编写 的 程序 实现 对 图 像 大 小 的 任意 调整 。 运 行 本 
实例 ， 在 上 传 图 片 的 右 侧 ， 选 择 要 调整 图 片 的 大 小 比例 ， 然 后 单 击 “ 调 整 图 像 大 小 ”按钮 ， 运 行 结 果 如 图 6.16 
所 示 。 


本 


图 6.16 任意 调整 图 像 的 大 小 
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国 关键 技术 


任意 调整 上 传 图 片 大 小 方法 实现 的 原理 : 首先 ， 根 据 表单 中 提交 的 值 ， 获 取 指 定 图 片 的 存储 路 径 和 名 称 ， 
以 及 它 要 被 调整 的 比例 。 然 后 ， 应 用 getimagesize0 函 数 获取 指定 图 片 的 数据 。 接 着 ,定义 thumb() 方 法 ， 根 据 原 
始 图 片 的 数据 和 提交 的 调整 比例 数据 ， 判 断 是 根据 比例 缩放 还 是 进行 裁剪 。 最 后 ， 载 入 原始 图 片 并 定义 新 的 缩 
略图 ， 应 用 imageCopyResampled(O) 函 数 将 原始 图 像 复 制 到 新 的 缩 略 图 中 ， 并 将 新 的 图 像 存 储 到 指定 位 置 。 

imagecopyresampled(O) 函 数 从 原 图 像 中 采样 ， 复 制 部 分 图 像 重 新 生成 图 像 ， 详 细 说 明 请 参见 实例 278。 


< 注意 : 因为 调 色 板 图 像 的 限制 (255+1 种 颜色 ) ， 存 在 一 个 问题 。 重 新 采样 或 过 滤 图 像 通常 需要 多 于 255 
种 颜色 ， 计 算 新 的 被 重新 采样 的 像素 及 其 颜色 时 采用 了 一 种 近似 值 。 尝 试 为 调 色 板 图 像 分 配 一 个 新 
颜色 时 ， 如 果 失 败 那么 选择 计算 结果 最 接近 (理论 上 ) 的 颜色 (并 不 是 视觉 上 最 接近 的 颜色 ) 。 这 
可 能 会 产生 怪异 的 结果 ， 如 空白 (或 者 视觉 上 是 空白 ) 的 图 像 。 要 解决 这 个 问题 ， 可 使 用 真 彩色 图 
像 作 为 目标 图 像 ， 如 使 用 imagecreatetruecolor0) 函 数 创 建 的 图 像 。 


力 设计 过 程 
(1) 创建 一 个 图 片上 传 功能 ， 将 图 片上 传 到 服务 器 指定 的 文件 夹 下 ， 并 通过 文件 系统 函数 读 取 存储 在 指定 
目录 下 的 图 片 。 


(2) 在 图 片 输出 的 同时 ， 在 右 侧 创 建 一 个 表单 ， 提 交 图 片 的 存储 位 置 、 名 称 和 要 调整 的 尺寸 ， 将 数据 提交 
到 index_ok.php 文件 中 。 
(3) 创建 index_ok.php 文件 ， 包 含 thumbnail.php 文件 ， 实 例 化 image 类 ， 调 用 其 中 的 thumb0 方 法 ， 以 表 


单 中 提交 的 数据 作为 参数 ， 完 成 对 图 片 大 小 的 调整 ， 其 关键 代码 如 下 : 
<?php 


这 $_POST['Submit] 一 "调整 图 像 大 小 ){ 
include("thumbnail.php"); // 包 含 图 像 类 存储 文件 
Simg = new image(); /实例 化 图 像 处 理 类 


Sretum=$img->param($ POST['pic path'])->thumb("./thumbnail/".$ POSTTpic name1.$ POSTJpic width1$ POSTfpic height1.1): 
echo "<script>alert( 图 像 大 小 设置 成 功 ! '); window.location.href='index.php';</script>"; 

} 

?> 


(4) 创建 humbnail.php 文件 ， 编 写 image 类 ， 定 义 thumb0 方 法 ， 根 据 表单 中 提交 的 数据 ， 完 成 图 像 大 小 


的 调整 操作 。 其 关键 代码 如 下 : 
VWthumb( 新 图 地 址 ， 宽 , 高 , 裁剪 , 允许 放大 ) 
public function thumb($filename, $news_w = 100, $news_h = 100.Scut= 0.Sbig=0){ 
S$info = $this->getImageInfo ( $this->img ); // 获 取 源 图 信息 
if(! empty ($info [0] )) { 
S$old_w = $info [0]; 
S$old h = $info [1]: 
Snew_w = $old_w + $news_w:; 
Snew_h = $old_h * Snews h: 
Stype = $info [type1: 


Sext = $info [ext]: 

unset ( $info ); 

if($old w < $new_h && $old h < $new _w && ! Sbig) { // 如 果 源 图 比 缩 略 图 小 并 且 不 允许 放大 
Teturm false: 

} 

if(Scut— 1){ /居中 裁剪 


Sscalel = round ( $new_w /Snew_ h. 2): 
$scale2 = round (Sald w /Sold h 2) 
if($scalel > $scale2) { 
$end h=round (S$old_w / $scale1, 2 ); 
$start h= (gold_ h - Send h) /2; 
Sstart_ w=0; 
Send w= $old_w:; 
yelse{ 
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$end w=round ( $old h* $scalel,2); 
Sstart w= (S$old w- $end w)/2; 


Sstart h=0; 
Send h= $old h: 
} 
Swidth = Snew_w; // 定 义 图 像 宽 
Sheight = $new_h; // 定 义 图 像 高 
} 
ScereateFun = TmageCreateFrom' . $type; // 新 建 图 像 


Soldimg = $creatcFun ( $this->img ); 
if ($type (= 'gif && function_exists ( imagecreatetruccolor )) { 
Snewimg = imagecreatetruecolor ( $width, $height ); // 创 建新 的 真 彩 图 像 
}else { 
=imagecreate ( $width, Sheight ); /创建 新 的 图 像 


} 
if (function_exists ( "ImageCopyResampled" )) { 

ImageCopyResampled ( $newimg, $oldimg. 0. 0. $start_w, $start_h, $width, $height, $end_w, $end_h ); // 完 成 图 像 的 复制 
jelse{ 

ImageCopyResized ( Snewimg, $oldimg, 0, 0, $start_w, $start_h, $width, Sheight Send_w, Send_h ); 


$type 一 ‘jpeg’ && imageinterlace ( Snewimg, 1 ); // 对 jpeg 图 形 设置 隔行 扫描 
SimageFun = 'image' . $type; // 生 成 图 片 
1@SimageFun ( $newimg, $filename ) && die ( ' 保 存 失败 1"); 
ImageDestroy ( $newimg ); /销毁 图 像 
return $filename; /1/ 返 回 图 像 名 称 
} 
} 
国 秘 航 心 法 


心 法 领悟 285: 自制 图 像 处 理工 具 。 

在 本 实例 中 编写 的 只 是 一 个 可 以 按 比 例 任意 调整 图 像 大 小 的 方法 ， 如 果 读 者 感 兴趣 ， 可 以 对 这 个 方法 进行 
扩展 。 例 如 ， 向 图 像 中 添加 水 印 、 以 数值 的 形式 调整 图 像 大 小 、 向 图 像 中 添加 文字 以 及 给 图 像 生成 缩 略图 等 。 
如 果 将 这 些 功 能 综合 到 一 起 ， 那 么 它 就 变 成 了 一 个 简单 、 实 用 的 图 像 处 理工 具 了 。 本 实例 虽然 没有 将 这 些 功 能 
进行 整合 ， 但 是 这 里 提 到 的 每 种 方法 在 我 们 的 实例 中 都 有 体现 ， 读 者 可 以 尝试 自己 将 它们 整合 到 一 起 。 


中 级 | 


和 | 
实例 286 
me | 


趣味 指数 : 铺 庚 庚 容 
力 实例 说 明 


网 站 的 图 片 被 次 链 ， 是 一 件 让 人 非常 郁闷 的 事情 。 盗 链 不 仅 盗用 图 片 ， 更 直接 的 问题 是 用 户 在 下 载 资 链 人 
网 站 上 的 图 片 时 ， 会 给 服务 器 带 来 压力 ， 导 致 日 志 中 的 访问 记录 暴涨 ， 而 带宽 被 耗 尽 。 为 了 打击 盗 链 行为 ， 本 
实例 介绍 一 种 方法 一 一 Apache 防盗 链 技 术 ， 让 盗 链 者 的 某 些 小 伎俩 不 能 得 喜 。 

对 Apache 服务 器 进行 设置 后 ， 当 盗 链 者 盗 链 网 站 的 图 片 时 ， 将 输出 如 图 6.17 所 示 的 效果 。 


6.17 被 盗 链 图 片 和 盗 链 后 的 输出 结果 
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图 关键 技术 


要 防止 网 站 图 片 被 资 链 ， 就 要 先 了 解 盗 链 的 手段 ， 基 本 可 以 分 为 以 下 两 种 : 

加 ” 资 链 者 直接 使 用 图 片 链接 引用 网 站 上 的 图 片 。 

这 种 方式 就 是 实例 说 明 中 叙述 的 那 种 情况 ， 这 种 盗 链 行 为 是 可 以 完全 防止 的 。 

防止 这 种 盗 链 情况 的 发 生 ， 有 两 种 可 行 的 方法 : 通过 Apache 服务 器 进行 控制 和 使 用 SESSION 变量 在 程序 
中 进行 控制 。 

加 ” 资 链 者 直接 从 网 站 上 下 载 图 片 并且 复 制 使 用 。 

这 种 方式 不 可 能 被 真正 地 阻止 ， 我 们 能 做 的 只 是 让 它 的 下 载 更 加 困难 而 已 。 防 止 的 方法 有 屏蔽 页 面 中 的 右 
键 使 用 功能 、 禁 止 对 网 页 的 下 载 等 。 

Apache 防盗 技术 的 原理 与 PHP 伪 静 态 技术 的 原理 是 相同 的 ， 都 需要 应 用 Apache 的 mod_rewrite.so 模 组 。 
Apache 服务 器 的 配置 文件 httpd.conf 的 修改 方法 如 下 : 

(1) 打开 httpd.conf 文件 ， 定 位 到 如 下 位 置 : 


#0adModule rewrite_module modules/mod_rewrite.so 


将 该 项 前 面 的 “#” 去 掉 ， 并 启动 该 项 。 


(2) 查找 httpd.conf 文件 ， 找 到 其 中 的 AllowOverride 项 ， 将 它 的 值 都 修改 为 All。 保 存 并 重新 启动 Apache 
服务 器 ， 使 修改 生效 。 
(3) 在 实例 根 目录 下 创建 .htaccess 文件 ， 定 义 防止 网 站 图 片 被 盗 链 的 方法 。.htaccess 文件 的 代码 如 下 : 


SetEnvIfNoCase Referer "^http://192.168.1.59/" local re 会 1 
<FilesMatch ".(giflipg)"> 


加 ”Referer 字段 : 当 Apache 处 理 一 个 请 求 时 , 将 检测 头 信 息 里 的 Referer 字段 , 并 且 设 置 环境 变量 local ref 
为 1， 如 果 请 求 从 本 身 的 网 站 地 址 开始 ， 即 是 本 网 站 的 一 个 页 面 。 

加 ”^http://192.168.1.59/: 是 一 个 正则 表达 式 ， 为 了 设置 环境 变量 ，Referer 值 必须 与 其 匹配 。 

回 "NoCase" 指 令 ， 定义 正则 表达 式 的 值 ， 忽 略 字符 串 的 大 小 写 。 

回 ”Order Allow,Deny: 设置 Apache 对 当前 的 请 求 ， 将 执行 列表 中 的 Allow 指令 ， 然 后 重复 进行 Deny 
指令 。 

local ref: 设置 了 local ref 环境 变量 (无 论 什么 值 ) 的 请 求 ， 而 任何 其 他 的 请 求 将 被 拒绝 ， 因 为 它们 
不 符合 Allow 的 条 件 并 且 默 认 是 拒绝 访问 的 。 

这 就 是 通过 Apache 服务 器 来 防止 图 片 被 盗 链 的 方法 。 有 关 通 过 SESSION 变量 防止 图 片 被 盗 链 的 方法 将 在 

实例 287 中 进行 讲解 。 


图 设计 过 程 
这 里 沿用 实例 285 的 内 容 ， 并 在 其 基础 上 演示 如 何 通过 Apache 防止 网 站 图 片 被 盗 链 。 


(1) 修改 Apache 服务 器 的 配置 文件 httpd.conf， 具 体 步骤 请 参考 关键 技术 。 


(2) 在 实例 根 目录 下 创建 .htaccess 文件 ， 编 写 通过 Apache 服务 器 防止 图 片 被 盗 链 的 方法 ， 有 具体 代码 请 参 
考 关 键 技术 。 


(3) 在 另外 一 个 Apache 服务 器 上 重新 创建 一 个 程序 ， 在 程序 中 盗 链 本 实例 中 的 一 个 图 片 时 ， 将 出 现实 例 
说 明 中 所 示 的 运行 结果 。 


国 秘笈 心 法 


心 法 领悟 286: 在 Apache 服务 器 的 httpd.conf 文件 中 定义 防止 图 片 被 盗 链 的 方法 。 
在 本 实例 中 ， 防 止 图 片 被 盗 链 的 方法 只 对 本 实例 中 的 图 片 有 效 ， 如 果 将 .htaccess 文件 中 的 方法 定义 到 
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httpd.conf 中 ， 那 么 这 个 方法 将 对 本 服务 器 下 的 所 有 程序 都 有 效 。 


中 级 | 
实例 287 赵 味 指数 :全 本 三 从 | 
实例 说 明 ， 


本 实例 将 介绍 另外 一 种 网 站 图 片 防盗 链 方法 , 即 在 程序 中 通过 SESSION 
变量 防止 图 片 被 盗 链 。 当 网 站 中 应 用 了 SESSION 防盗 链 技术 后 ， 如 果 网 站 
的 图 片 被 资 链 ， 将 输出 如 图 6.18 所 示 的 效果 。 


图 关键 技术 图 6.18 资 链 后 的 输出 结果 
通过 SESSION 防盗 链 与 通过 SESSION 屏蔽 页 面 刷新 对 计数 器 的 影响 原理 相同 。 在 页 面 中 ， 首 先 初始 化 

SESSION 变量 , 定义 一 个 SESSION 变量 并 赋值 为 TRUE。 然后 在 插入 图 像 的 <img> 标 签 中 定义 src 的 属性 值 时 ， 

不 直接 定义 指定 图 片 的 位 置 ， 而 是 链接 到 指定 的 .php 文件 中 ， 并 且 将 要 插入 的 图 像 名 称 作为 超 链 接 的 参数 值 传 


递 到 .php 文件 中 。 最 后 ,在 .php 文件 中 ,通过 判断 SESSION 变量 的 值 是 否 为 真 ， 决 定 超 链 接 中 传递 的 图 片 是 否 
被 输出 ， 从 而 完成 对 网 页 中 图 片 的 保护 。 


图 设计 过 程 
(1) 设计 一 个 简单 的 网 页 。 首 先 在 这 个 页 面 中 初始 化 一 个 SESSION 变量 ， 并 且 设置 变量 的 值 为 TRUE。 
然后 在 <img> 标 签 中 ， 将 sre 的 属性 值 指定 到 getimage.php 文件 中 ， 并 且 将 插入 的 图 像 名 称 设置 为 超 链接 的 参数 


值 ， 其 关键 代码 如 下 : 
<2php 
session_start(); // 初 始 化 SESSION 变量 
$_SESSION['viewimages']=true:; // 定 义 SESSION 变量 并 为 其 赋值 
?> 
<tr> 


<td colspan="2"> 
<img src="getimage .php?img=bg3_01jpg" width="267" height="31" alt="></td> 
<td> 
<img sre="getimage.php?img=bg3_02 jpe" width="536" height="31" alt="></td> 


</t> 
(2) 创建 getimage.php 文件 ， 在 该 文件 中 通过 对 SESSION 变量 值 的 判断 决定 是 否 输 出 图 像 ， 其 关键 代码 
如 下 : 
<?php 
session_start(); // 初 始 化 SESSION 变量 
让 (isset($_SESSION[vicwimages]) && $_SESSION[viewimages] 一 true) { /| 判断 SESSION 变量 是 否 为 真 
ES GET [img])) { // 超 链接 传递 的 值 是 否 存在 


= getimagesize ( ‘images/" . $_GET [img] ): // 获 取 超 链接 传递 图 片 的 信息 

es 'Content-Disposition: inline; filename=" . $_GET [img] ): 

header ( 'Content-Type:’ . $dims [mime'] ): 

header ( 'Content-Length:' . filesize (images/ . $_GET [img] ) ): 

readfile (‘images/' . $_GET [img] ): // 完 成 对 图 片 的 读 取 操作 
}else { 

("HTTP/1.1 404 NOT Found" ); 

header ( "Content-Type: text/plain" ); 

echo "图 像 不 存在 ! \n"; 
} 
}else{ 
header ( "HTTP/1.1 404 NOT Found" ): 
header ( "Content-Type: text/plain" ): 
echo "这 是 一 个 被 保护 的 图 像 不 可 盗 链 ! \n"; 
} 
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心 法 领悟 287: 防止 图 片 被 盗 链 方 法 的 选择 。 
通过 SESSION 变量 防盗 链 相对 通过 Apache 防盗 链 来 说 麻烦 一 些 ， 但 是 如 果 要 在 购买 的 虚拟 主机 中 使 用 ， 
那么 必须 考虑 虚拟 主机 的 Apache 配置 是 否 支持 mod_rewrite.so 模 组 。 而 使 用 SESSION 变量 来 防止 图 片 被 盗 链 ， 


则 不 必 考 虑 这 个 问题 ， 因 为 它 完 全 是 在 用 户 的 程序 中 运行 。 所 以 ， 具 体 使 用 哪 种 方法 来 防止 网 站 图 片 被 盗 链 ， 
可 以 根据 实际 情况 而 定 。 


6.3 ”JpGraph 类 库 


JpGraph 是 基于 GD2 函数 库 编写 的 主要 用 于 创建 统计 图 的 类 库 。 在 绘制 统计 图 方面 不 仅 功能 非常 强大 ， 而 
且 代码 编写 方便 ， 只 需 简单 的 几 行 代码 就 可 以 绘制 出 非常 复杂 的 统计 图 效果 ， 从 而 很 大 程度 地 提高 了 编程 人 员 
的 开发 效率 。 在 本 节 中 ， 将 通过 设计 各 种 类 型 的 统计 图 ， 让 大 家 全 面 地 体会 了 pGraph 类 库 的 强大 功能 。 


一 po 


力 实例 说 明 


在 本 实例 中 ， 将 介绍 如 何 通过 JpGraph 类 库 创 建 柱 形 图， 完成 对 产品 月 销售 量 的 统计 分 析 ， 其 运行 效果 
如 图 6.19 所 示 。 


6.19 ” 柱 形 图 分 析 产品 月 销售 量 


图 关键 技术 


要 运用 JpGraph 类 库 ， 首 先 必须 了 解 它 如 何 下 载 、 有 哪些 版 本 、 适 用 于 哪些 环境 。JpGraph 包括 JpGraph 1.x 
系列 、JpGraph 2.x 系列 和 JpGraph 3x 系列 。 

回 “JpGraph 1.x 系列 仅 适 用 于 PHP 4 环境 ，PHP 5 下 不 能 工作 。 

加 ”JpGraph 2x 系列 仅 适 用 于 PHP 5 环境 (三 5.1.x),PHP 4 下 不 能 工作 。 目 前 2.x 系列 的 最 新 版 本 是 2.3.4。 

加 ”JpGraph 3.x 系列 是 2.x 的 升级 版 本 ， 目 前 最 新 的 版 本 是 3.5.0b1。 

本 书 中 应 用 的 是 最 新 版 本 JpGraph 3.0.6。 

配置 了 pGraph 的 最 简单 的 方法 就 是 将 解压 后 的 sr 文件 夹 直接 复制 到 范例 的 根 目录 下 。 这 样 就 可 以 直接 在 程 
序 中 调用 sre 文件 夹 下 的 文件 ， 应 用 JpGraph 类 库 绘 制 统计 图 。 
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图 设计 过 程 
(1) 将 于 Graph 类 库 导入 到 程序 中 。 
使 用 卫 Graph 类 库 , 首先 要 从 网 站 http://www.aditus.nu/jpgraph/ 下 载 该 类 库 的 压缩 包 并 解压 ,将 呈现 如 图 6.20 
所 示 的 目录 结构 。 


[Er 便 用 文档 
Be 短文 

目 opues 版 权 声明 

国 nEaowE 关 库 文件 介绍 
国 version 版 本 声明 


图 6.20 JpGraph 压缩 包 解压 后 的 目录 


(2) 将 src 文件 夹 复制 到 实例 的 根 目录 下 。 
(3) 创建 ndex.php 文件 ， 将 Graph 导入 到 项 目 中 ， 具 体操 作 步 又 如 下 : 


回 “使 用 Graph 类 创建 统计 图 对 象 。 
加 ”调用 Graph 类 的 SetScale0 方 法 设置 统计 图 的 刻度 样式 。 
加 ”调用 Graph 类 的 SetShadow0 方 法 设置 统计 图 阴影 。 
加 ”调用 Graph 类 的 img 属性 的 SetMargin0 方 法 设置 统计 图 的 边界 范围 。 
回 ”调用 BarPlot 类 创建 统计 图 的 柱 形 效果 。 
加 ”调用 BarPlot 类 的 SetFillColor0 方 法 设置 柱 形 图 的 前 景色 。 
index.php 的 关键 代码 如 下 : 
<?ph 
让 "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
Tequire_once 'srelipgraph.php': /导入 JpGraph 类 库 
require_once 'sre/jpgraph_bar.php'; // 导 入 JpGraph 类 库 的 柱 形 图 功能 
S$data = array(80, 73, 89, 85, 92); // 设 置 统计 数据 
$datas = array("C#", "VB", "VC", "Java", "ASP.NET"): // 设 置 统计 数据 
$graph = new Graph(600, 300); /设置 画布 大 小 
Sgraph->SetScale('textlin); /设置 坐标 刻度 类 型 
Sgraph->SetShadowO); /设置 画布 阴影 
Sgraph->img->SetMargin(40, 30, 20. 40): /设置 统计 图 边 距 
Sbarplot = new BarPlot($data); // 实 例 化 BarPlat 对 象 
S$barplot->SetFillColor('blue'); // 设 置 柱 形 图 前 景色 
Sbarplot->value->Show(); 
Sgraph->Add($barplot): 
S$graph->title->Set(iconv("utf-8","gb2312"." 吉 林 省 明日 科技 有 限 公司 6 月 份 编程 词典 销售 量 分 析 ")); // 统 计 图 标题 
Sgraph->xaxis->title->Set(iconv("utf-8"."gb2312"," 部 门 ")); 1/ 设置 X 轴 名 称 
Sgraph->xaxis->SetTickLabels($datas); 
S$graph->yaxis->title->Set(iconv("utf-8"."gb2312",' 总 数量 (本 ))); // 设 置 Y 轴 名 称 
S$graph->title->SetFont(FF_SIMSUN. FS_BOLD): // 设 置 标题 字体 
Sgraph->xaxis->title->SetFont(FF_SIMSUN.FS_BOLD): // 设 置 X 轴 字体 
Sgraph->yaxis->title->SetFont(FF_SIMSUN.FS_BOLD): 1/ 设置 Y 轴 字体 
Sgraph->Stroke(); /输出 图 像 
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心 法 领悟 288: JpGraph 在 Apache 服务 器 下 的 通用 配置 。 
如 果 想 要 了 Graph 在 Apache 服务 器 下 的 所 有 站 点 均 有 效 ， 可 以 按 如 下 步骤 进行 配置 : 
(1) 将 解压 后 的 sre 文件 夹 保存 到 服务 器 磁盘 中 ， 如 C:\jpgraph。 
(2) 编 辑 php.ini 文件 , 修改 include_path 的 配置 项 , 在 该 项 后 增加 JpGraph 类 库 的 保存 目录 , 如 include_path 
=".;c:Ypgraph"。 
(3) 重新 启动 Apache 服务 ， 配 置 生效 。 
这 样 了 Graph 就 在 Apache 服务 器 下 的 所 有 站 点 中 都 有 效 了 。 
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实例 289 


力 实例 说 明 
在 本 实例 中 ， 运 用 卫 Graph 生成 柱 形 图 对 公司 年 度 总 的 收 支 情况 进行 分 析 ， 其 运行 结果 如 图 6.21 所 示 。 
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图 6.21 公司 年 度 收 支 展示 


总 金额 (万 元 ) 
各 2 


图 关键 技术 


在 本 实例 中 以 年 为 单位 ， 分 析 在 一 年 中 公司 每 个 月 的 收 支 情况 。 首 先 确立 一 年 中 每 个 月 的 业绩 ， 然 后 确定 
柱 形 图 的 标题 、X 轴 、Y 轴 显 示 的 内 容 ， 最 后 将 src/ipgraph.php 导入 到 项 目 中 ， 完 成 柱 形 图 的 创建 ， 其 具体 方 
法 解析 如 下 : 

(1) 通过 include EE li 在 本 实例 中 创建 柱 形 图 ， 需 要 使 用 的 文件 如 下 : 


require_once '../sre/jpgraph.php'; // 导 入 JpGraph 类 
Tequire_once '../sre/jpgraph_bar.php'; /导入 JpGraph ee 


(2) 使 用 Graph 类 创建 统计 图 对 象 。 


使 用 卫 Graph 类 库 首 先 需要 创建 统计 图 对 象 ， 统 计 图 对 象 使 用 Graph 类 创建 ， 该 类 的 使 用 语法 如 下 : 
Sgraph = new Graph(Sw, $h); 


参数 说 明 : 
Sw: 指定 图 片 的 宽度 。 
$h: 指定 图 片 的 高 度 。 
(3) 调用 Graph 类 的 SetScale0 方 法 设置 统计 图 的 刻度 样式 。 
统计 图 的 XX 轴 和 YY 轴 的 样式 有 多 种 , 可 以 使 用 Graph 类 的 SetScale0 方 法 设置 统计 图 刻度 的 样式 , SetScaleO 
方法 的 语法 如 下 : 


Sgraph->SetScale($type) 


$type: 表示 XX 轴 样 式 和 YY 轴 样 式 的 组 合 ， 具 体 组 合 方式 如 表 6.2 所 示 。 
表 6.2 SetScale() 方 法 X 轴 与 Y 轴 样 式 说 明 


坐 标 轴 直线 样式 文本 样式 对 数 样 式 整数 样式 
XxX | Lin text Log Int 
和 Lin 无 Log Int 


例如 ，textlog 表示 X 轴 坐 标 为 文本 样式 ，Y 轴 为 对 数 样式 的 X-Y 刻度 。 
(4) 调用 Graph 类 的 SetShadow0 方 法 设置 统计 图 阴影 。 
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默认 情况 下 ,应 用 名 Graph 绘制 出 统计 图 的 下 边框 和 右边 框 是 没有 阴影 效果 的 ,使 用 Graph 类 的 SetShadow0 
方法 可 以 为 统计 图 添加 阴影 效果 ， 从 而 使 统计 图 具有 立体 感 。SetShadow0 方 法 的 语法 如 下 : 


Sgraph->SetShadowO) 
(5) 调用 Graph 类 的 img 属性 的 SetMargin0 方 法 设置 统计 图 的 边界 范围 。 
使 用 SetMargin0) 方 法 可 以 为 统计 图 设置 边界 范围 ， 使 统计 图 制作 变 得 更 为 灵活 ， 该 方法 的 语法 如 下 : 
Sgraph->img->SctMargin($left, Sright, $up, $bottom) 
参数 说 明 : 
S$left: 统计 图 左边 距 。 
Sright: 统计 图 右边 距 。 
S$up: 统计 图 上 边 距 。 
$bottom: 统计 图 下 边 距 。 
(6) BarPlot 类 创建 统计 图 的 柱 形 效果 。 
使 用 IpGraph 创建 柱 形 图 需要 使 用 BarPlot 类 ， 该 类 的 构造 方法 中 包含 一 个 数值 数组 参数 ， 该 数组 的 内 容 即 
为 需要 统计 的 数据 。BarPlot 类 的 语法 如 下 : 


$barPlot = new BarPlot($data) 
$data: 由 统计 数据 所 组 成 的 数组 。 
(7) 调用 BarPlot 类 的 SetFillColor0 方 法 设置 柱 形 图 的 前 景色 。SetFillColor0 方 法 的 语法 如 下 : 


S$barplot->SetFillColor($color); 


$color: 要 设置 的 颜色 值 。 


ss 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 页 面 的 编码 格式 ， 将 sre 文件 夹 导 入 实例 根 目录 下 。 
header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
require_once '../sre/jpgraph.php'; // 导 入 JpGraph 类 库 
require_once '../sre/jpgraph_bar.php'; /导入 JpGraph 类 库 的 柱 形 图 功能 
(2) 应 用 卫 Graph 类 库 中 的 方法 完成 柱 形 图 的 创建 ， 其 关键 代码 如 下 : 
<?php 
header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
require_once 'src/jpgraph.php'; // 导 入 JpGraph 类 库 
require_once 'src/jpgraph_bar.php'; // 导 入 JpGraph 类 库 的 柱 形 图 功能 
Sdata = array(80, 73, 89. 85, 92, 75 ,85 .65. 84. 79, 85. 98): /设置 统计 数据 
$graph = new Graph(600, 300); // 设 置 画布 大 小 
Sgraph->SetScale('textlin): 1/ 设置 坐标 刻度 类 型 
Sgraph->SetShadowO: /设置 画布 阴影 
Sgraph->img->SetMargin(40, 30. 20. 40): // 设 置 统计 图 边 距 
Sbarplot = new BarPlot($data); /实例 化 BarPlat 对 象 
S$barplot->SetFillColor('blue’): // 设 置 柱 形 图 前 景色 
Sbarplot->value->Show(); 
Sgraph->Add($barplot); 
S$graph->title->Set(iconv("utf-8","gb2312", 公 司 2009 年 度 收 支 )): // 设 置 统计 图 标题 
Sgraph->xaxis->title->Set(iconv("utf-8"."gb2312", 月 份 )); // 设 置 义 轴 名 称 
S$graph->yaxis->title->Set(iconv("utf-8","gb2312", 总 金额 (万 元 )); // 设 置 Y 轴 名 称 
Sgraph->title->SetFont(FF_SIMSUN. FS_BOLD): // 设 置 标题 字体 
Sgraph->xaxis->title->SetFont(FF_SIMSUN.FS_BOLD): // 设 置 义 轴 字 体 
Sgraph->yaxis->title->SetFont(FF_SIMSUN.FS_BOLD): // 设 置 Y 轴 字体 
Sgraph->StrokeO; // 输 出 图 像 


心 法 领悟 289: 转换 编码 格式 的 重要 性 。 

由 于 本 实例 采用 的 是 UTF-8 编码 ， 所 以 在 生成 的 图 像 中 输出 中 文字 符 串 时 ， 必 须 对 其 进行 编码 转换 ， 同 时 
要 设置 字体 为 SetFont(FF_SIMSUN, FS_BOLD)， 如 果 使 用 其 他 类 型 的 字体 ， 即 使 完成 编码 转换 ， 输 出 的 中 文字 
符 串 仍然 是 乱码 。 


390 


第 6 章 图 形 图 像 处 理 


力 实例 说 明 
在 本 实例 中 , 运用 JpGraph 生成 对 比 柱 形 图 , 对 编程 词典 6、7 月 份 的 销售 量 进行 比较 , 其 运行 结果 如 图 6.22 


所 示 。 


6.22 ”编程 词典 6、7 月 份 销量 对 比 


图 关键 技术 


在 本 实例 中 通过 柱 形 图 完成 对 编程 词典 6、7 月 份 销量 的 对 比 。 此 例 在 单一 柱 形 图 的 基础 上 增加 一 组 柱 形 图 ， 
形成 两 组 数据 的 对 比 效果 ， 其 实现 方法 与 单一 柱 形 图 是 相同 的 ， 可 以 说 是 创建 两 个 单一 的 柱 形 图 ， 然 后 将 其 在 
同一 图 像 中 输出 。 

(1) 通过 BarPlot 类 创建 柱 形 图 , 运用 其 返回 对 象 调用 value0 方 法 中 的 Show0 方 法 输出 数据 , 通过 SetColor0 
方法 设置 输出 数据 颜色 。 


SetColor0 方 法 的 语法 如 下 : 
SetColor($aColor, $aLabelColor) 


参数 说 明 : 

$aColor: 设置 坐标 轴 的 颜色 ; 

$aLabelColor: 设置 坐标 轴 上 标签 的 颜色 ， 默 认 值 为 FALSE。 

(2) 通过 Add0 方 法 将 柱 形 图 数据 添加 到 图 像 中 ， 其 参数 是 柱 形 图 创建 返回 的 对 象 ， 语 法 如 下 : 

Ai 

$aPlot: 指定 图 像 创建 时 返回 的 对 象 。 

(3) 在 本 实例 中 ， 还 应 用 到 GroupBarPlot 类 创建 柱 形 图 数组 ， 通 过 该 类 可 以 实现 对 柱 形 图 的 分 段 处 理 ， 如 
果 重 新 设置 数组 $datazero 的 值 ， 那 么 柱 形 图 会 发 生 一 些 变化 。 


Class GroupBarPlot Extends BarPlot 
GroupBarPlot :: 
GroupBarPlot($plots) 


GroupBarPlot 创建 一 个 新 的 图 像 对 象 ，$plots 是 一 个 数组 。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 


JpGraph 文件 。 
(2) 应 用 卫 Graph 类 库 中 的 方法 完成 对 比 柱 形 图 的 创建 ， 其 关键 代码 如 下 : 
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<?php 

header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文 件 编码 格式 
include ("../src/jpgraph.php"); // 导 入 文件 
include ("../sre/jpgraph_bar.php"); // 导 入 文件 
Sdata_july = array(90, 63, 69, 105, 92): // 设 置 统计 数据 
$data_june = array(180, 173, 189, 145, 202): // 设 置 统计 数据 
Sdatazero=array(0,0,0,0,0); 

$datas = array("C#", "VB", "VC", "Java", "ASP.NET"); // 设 置 统 计数 据 
Sgraph = new Graph(600,270); // 创 建 图 像 
Sgraph->SetScale("textlin"); // 设 置 坐标 刻度 类 型 
Sgraph->SetY2Scale("lin"); 

Sgraph->img->SetMargin(50, 40, 20. 40); // 设 置 统计 图 边 距 
Sgraph->yaxis->scale->SetGrace(20); 

Sgraph->y2axis->scale->SetGrace(20); 

S$graph->SetMarginColor(white’); /创建 背景 颜色 
Sgraph->y2axis->SetColor(darkred'): 

S$bplotzero = new BarPlot($datazero); // 设 置 图 像 的 填充 值 
S$ybplot] = new BarPlot($data_july); /创建 6 月份 数据 
Sybplotl->value->Show(0); 

S$ybplot = new GroupBarPlot(array($ybplot1,$bplotzero)); 

S$ybplot2 = new BarPlot($data_june); /创建 7 月 份 数据 
S$ybplot2->value->Show(; /输出 数据 
S$ybplot2->value->SetColor(darkred'): 

S$ybplot2->SetFillColor( darkred'); 

S$y2bplot = new GroupBarPlot(array($bplotzero,$ybplot2)); 

// 将 数据 添加 到 图 像 中 

Sgraph->Add($ybplot); 

Sgraph->AddY2($y2bplot); 

Sgraph->title->Set(iconv("utf-8","gb2312", 编 程 词典 2009 年 6、7 月 份 销售 对 比 ); // 设 置 统计 图 标题 
S$graph->xaxis->title->Set(iconv("utf-8","gb2312",'6、7 月 份 ); // 设 置 X 轴 名 称 
Sgraph->xaxis->SetTickLabels($datas); 

S$graph->yaxis->title->Set(iconv("utf-8"."gb2312",' 总 金额 (万 元 ))); // 设 置 Y 轴 名 称 
S$graph->title->SetFont(FF_SIMSUN. FS_BOLD): /设置 标题 字体 
Sgraph->xaxis->title->SetFont(FF_SIMSUN.FS_BOLD): 1/ 设置 X 轴 字体 
Sgraph->yaxis->title->SetFont(FF_SIMSUN.FS_BOLD): // 设 置 Y 轴 字体 
Sgraph->Stroke(); // 生 成 图 像 

> 
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心 法 领悟 290: 字体 设置 的 重要 性 。 

在 通过 JpGraph 类 库 创 建 图 像 时 ， 要 想 在 图 像 中 输出 中 文字 符 串 ， 只 对 字符 串 的 编码 格式 进行 转换 是 不 够 
的 ， 还 要 为 中 文字 符 串 设置 正确 的 字体 〈SetFont(FF_SIMSUN, FS_BOLD)) ， 和 否则 无 论 怎么 转换 字符 串 的 编码 
格式 都 是 徒劳 的 。 


高 级 1 
实例 291 趣味 指数 : dododole, 
实例 说 明 


在 本 实例 中 , 运用 JpGraph 生成 柱 形 图 , 对 公司 编程 词典 上 半年 的 销量 进行 统计 , 其 运行 结果 如 图 6.23 
所 示 。 
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图 6.23 编程 词典 上 半年 销量 展示 


图 关键 技术 


在 本 实例 中 ， 对 编程 词典 上 半年 的 销量 进行 分 析 ， 这 里 创建 的 柱 形 图 与 上 面 实例 创建 的 柱 形 图 的 唯一 区 别 
是 形状 和 颜色 不 同 。 
本 实例 通过 BarPlot 类 中 的 SetFillGradient0 方 法 ， 完 成 对 柱 形 图 颜色 和 形状 的 设置 ， 其 语法 如 下 : 


SetFillGradient($aFromColor, $aToColor, $aStyle) 
参数 说 明 ， 

$aFromColor: 默认 颜色 。 
$aToColor: 转换 的 颜色 。 

$aStyle: 设置 的 样式 。 

本 实例 中 的 具体 应 用 如 下 : 


SetFillGradient ("navy","#FFFF00",GRAD_LEFT_REFLECTION); // 设 置 图 像 的 类 型 和 填充 颜色 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文 件 夹 06 下 的 
JpGraph 文件 。 


(2) 应 用 pGraph 类 库 中 的 方法 完成 特殊 柱 形 图 的 创建 ， 其 关键 代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
include (".,/sre/jpgraph.php"): 
include (",/sre/jpgraph_bar.php"): 
Sdatay=array(150,201,145,340,265.365); 
Sdatax=array("Jan", "Feb","Mar","Apr","May","June"); 
S$graph = new Graph(400,200,"auto"); // 创 建 图 像 
Sgraph->img->SetMargin(60,20,30,50); /设置 图 像 边框 间距 
Sgraph->SetScale("textlin"); /定义 坐标 刻度 类 型 
S$graph->SetMarginColor("lightblue' // 定 义 图 像 颜色 
Sgraph->title->Set(iconv("utf-8". Se ,编程 词典 上 半年 总 的 销售 量 分 析 )): // 定 义 标题 
S$graph->title->SetFont(FF_SIMSUN, FS_BOLD): /设置 标题 字体 
Sgraph->xaxis->SetFont(FF_VERDANA.FS_NORMAL.10): /设置 X 轴 的 字体 
Sgraph->yaxis->SetFont(FF_VERDANA.FS_NORMAL.10): // 设 置 Y 轴 的 字体 
Sgraph->xaxis->SetTickLabels($datax): // 设 置 X 轴 输出 的 数据 
Sgraph->xaxis->SetLabelAngle(50): // 设 置 输出 文字 大 小 
S$bplot = new BarPlot($datay): /实例 化 图 像 创建 类 
S$bplot->SetWidth(0.6); /设置 柱 形 图 的 输出 大 小 
S$bplot->SetFillGradient("navy","#FFFF00".GRAD LEFT REFLECTION): // 设 置 图 像 的 类 型 和 填充 颜色 
$bplot->SetColor("white"); // 设 置 图 像 边 框 颜 色 
Sgraph->Add($bplot); /添加 数据 
S$graph->Stroke0; /生成 图 像 
?> 
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心 法 领悟 291: SetFillGradient0 方 法 的 妙用 。 
通过 SetFillGradient0 方 法 不 但 可 以 改变 柱 形 图 的 形状 ， 还 可 以 使 柱 形 图 变 得 更 加 光滑 ， 其 方法 如 下 : 


//$bplot->SetFillGradient("navy". "lightsteelblue".GRAD_MIDVER): 
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力 实例 说 明 
在 本 实例 中 ， 运 用 卫 Graph 生成 柱 形 图 ， 对 公司 年 度 总 的 收 支 情况 进行 分 析 ， 其 运行 结果 如 图 6.24 所 示 。 


公司 2009 年 上 半年 总 的 销售 宣 


图 6.24 公司 2009 年 上 半年 总 销售 额 


图 关键 技术 


在 本 实例 中 ， 通 过 柱 形 图 展示 公司 2009 年 上 半年 总 的 销售 额 ， 这 个 柱 形 图 的 特点 体现 在 背景 图 像 、X 轴 时 
间 、 数 据 输 出 和 数据 的 格式 化 上 。 

(1) 通过 图 像 的 SetFrame( 方 法 控制 背景 图 像 ， 其 语法 如 下 : 

SetFrame($aDrawImgFrame, SalmgFrameColor, $almgFrame Weight) 

参数 说 明 : 

$aDrawImgFrame: 如 果 将 该 参数 设置 为 FALSE， 那 么 就 不 输出 背景 图 像 ， 如 果 设 置 为 TRUE 或 者 不 应 用 
该 方法 ， 那 么 将 输出 背景 图 像 。 

$aImgFrameColor: 该 参数 是 一 个 数组 ， 定 义 背 景 图 像 的 颜色 。 

$aImgFrameWeight: 默认 值 为 1， 设置 背景 宽度 。 

(2) X 轴 上 时 间 的 设置 。 大 家 可 以 看 到 ，X 轴 上 的 时 间 坐 标 采用 的 是 月 份 的 英文 简写 格式 ， 这 个 时 间 数 据 
不 是 通过 数组 定义 的 ， 而 是 应 用 GetShortMonth0 方 法 直接 生成 的 ， 其 代码 如 下 : 


$a = $gDateLocale->GetShortMonth(); // 定 义 义 轴 输 出 的 内 容 ， 英 文 月 份 的 简写 
然后 通过 图 像 中 xaxis 对 象 中 的 SetTickLabels0 方 法 将 数据 添加 到 义 轴 上 ， 其 代码 如 下 : 
Sgraph->xaxis->SetTickLabels($a): // 添 加 数据 


(3) 柱 形 图 中 数据 的 输出 应 用 的 是 柱 形 图 value 对 象 中 的 Show0 方 法 ， 然 后 应 用 SetAngle() 方 法 设置 数据 
的 输出 角度 ， 应 用 SetFormat0 方 法 对 数据 进行 格式 化 ， 其 关键 代码 如 下 : 


S$bplot->value->Show(): /| 输出 图 像 对 应 的 数据 值 
S$bplot->value->SetAngle(45); // 定 义 图 像 值 的 输出 角度 
S$bplot->value->SetFormat('$ %0.0f); 1/ 对 输出 值 进 行 格式 化 


(4) 调用 自 定义 函数 ， 对 数据 进行 格式 化 操作 。 本 实例 应 用 图 像 中 yaxis 对 象 中 的 SetLabelFormatCallbackO 
方法 调用 自 定义 函数 ， 执 行 数据 的 格式 化 操作 ， 其 关键 代码 如 下 : 
Sgraph->yaxis->SetLabelFormatCallback('yScaleCallback): /执行 数字 的 格式 化 输出 
其 中 yScaleCallback 为 自 定义 函数 的 名 称 。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文 件 夹 06 下 的 
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JpGraph 文件 。 
(2) 应 用 pGraph 类 库 中 的 方法 创建 一 个 没有 背景 图 像 的 柱 形 图 ， 其 关键 代码 如 下 : 
<?php 
header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
include ("../sre/jpgraph.php"); 
include ("../src/jpgraph_bar.php"); 
function yScaleCallback($aVal) { // 定 义 数 字 格 式 化 的 方法 
retum number format($aVal); 
} 
Sdatay=array(120567,134013,192000,87000,98000,45000); 
Sgraph = new Graph(650,280,'auto); // 创 建 图 像 
$graph->img->SetMargin(80.30.30.40): /定义 图 像 边 框 间距 
Sgraph->SetScale("textint"); // 定 义 刻度 值 的 类 型 
Sgraph->SetShadow(); // 设 置 图 像 阴影 
Sgraph->SetFrame(false); // 不 设置 图 像 的 背景 
Sgraph->yaxis->scale->SetGrace(35); /设置 了 轴 距 离 顶部 的 距离 
Sgraph->yaxis->SetLabelFormatCallback('yScaleCallback); // 执 行 数 字 的 格式 化 输出 


$a = $gDateLocale->GetShortMonthO; 
Sgraph->xaxis->SetTickLabels($a): 


// 定 义 义 轴 输 出 的 内 容 ， 英 文 月 份 的 简写 
// 添 加 数据 


Sgraph->xaxis->SetFont(FF_FONT2); // 设 置 字体 
S$graph->title->Set(iconv("utf-8","gb2312", 公 司 2009 年 上 半年 总 的 销售 额 )): // 定 义 标题 
S$graph->title->SetFont(FF_SIMSUN. FS_BOLD): // 设 置 标题 字体 
Sgraph->xaxis->title->Set("Year 2009"); // 设 置 义 轴 的 角 标 
Sgraph->xaxis->title->SetFont(FF_FONT2,FS_BOLD): // 定 义 字 体 
Sbplot = new BarPlot($datay); // 创 建 图 像 
$bplot->SetFillColor("orange"); // 定 义 图 像 的 填充 颜色 
$bplot->SetWidth(0.5); 1/ 设置 图 像 的 大 小 
$bplot->SetShadowO: // 设 置 图 像 的 阴影 
S$bplot->value->Show0: // 输 出 图 像 对 应 的 数据 值 
S$bplot->value->SetFont(FF_ARIAL.FS_BOLD); // 定 义 图 像 值 的 字体 
S$bplot->value->SetAngle(45); // 定 义 图 像 值 的 输出 角度 
Sbplot->value->SetFormat('$ %0.0f); // 对 输出 值 进行 格式 
S$bplot->value->SetColor("black","darkred"); // 定 义 值 的 颜色 
S$graph->Add($bplot); // 添 加 数据 
S$graph->Stroke(); // 生 成 图 像 
?> 
WE 
国 秘笈 心 法 


心 法 领悟 292: 通过 JpGraph 创建 图 像 的 技巧 。 

在 通过 JpGraph 类 库 创建 图 像 时 ， 可 以 在 sre\Examples 文件 夹 下 选择 想 要 创建 的 图 像样 式 ， 然 后 向 这 个 样 
式 中 添加 属于 自己 的 数据 ， 如 果 感 觉 不 满意 ， 可 以 对 大 小 、 颜 色 等 进行 重新 调整 。 这 是 通过 JpGraph 创建 图 像 
最 简单 、 最 直接 的 方法 。 


9 9 年 第 一 季度 编程 词典 销量 高 级 | 
实例 293 趣味 指数 : dodolodal 
图 实例 说 明 


在 本 实例 中 ， 运 用 了 Graph 生成 柱 形 图 ， 对 编程 词典 2009 年 第 一 季度 的 销量 情况 进行 分 析 ， 其 运行 结果 如 
图 6.25 所 示 。 


图 关键 技术 


在 本 实例 中 , 通过 多 柱 形 图 展示 2009 年 第 一 季度 编程 词典 的 销量 , 其 中 包括 C#、VB、VC、 Java 和 ASPNET 
5 个 语言 编程 词典 的 销量 。 
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公司 2009 年 第 一 季度 编程 局 碳 销 售 情况 
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图 6.25 2009 年 第 一 季度 编程 词典 销量 展示 


本 实例 中 柱 形 图 创建 体现 的 是 多 柱 形 图 直接 对 比 输出 ， 其 关键 是 将 BarPlot 类 创建 的 单 柱 形 图 通过 
GroupBarPlot 类 整合 到 同一 个 图 像 中 进行 输出 。 
(1) BarPlot 类 创建 统计 图 的 柱 形 效 果 。 
使 用 了 Graph 创建 柱 形 图 需要 使 用 BarPlot 类 ， 该 类 的 构造 方法 中 包含 一 个 数值 数组 参数 ， 该 数组 的 内 容 即 
为 需要 统计 的 数据 。 i 


SbarPlot = new BarPlot($data) 
Sdata: 由 统计 数据 所 组 成 的 数组 。 
(2) GroupBarPlot 类 创建 多 个 柱 形 效果 。 
使 用 JpGraph 创建 多 个 柱 形 图 需要 使 用 GroupBarPlot 类 ， 该 类 的 构造 方法 中 包含 一 个 数组 参数 ， 该 数组 的 


内 容 即 为 需要 整合 的 单个 柱 形 图 对 象 。GroupBarPlot 类 的 语法 如 下 : 
S$gbarplot= new GroupBarPlot ($data) 


$data: 由 单个 柱 形 图 对 象 所 组 成 的 数组 。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 
JpGraph 文件 。 


(2) 应 用 JpGraph 类 库 中 的 方法 创建 一 个 柱 形 图 数组 ， 对 2009 年 第 一 季度 编程 词典 销量 进行 分 析 ， 其 关 
键 代码 如 下 : 


S$datay1=array(140.110.50.60.45); 
S$datay2=array(35.90.190.80.120): 


SP-NET 
Year 2009 


S$datay3=array(20.60.70.100.60): 

S$graph = new Graph(600.400): /创建 图 像 
Sgraph->SetScale("textlin"); /设置 刻度 值 类 型 
S$graph->SetMargin(40.30.30.40); /定义 边框 距离 
S$graph->SetMarginColor('white:0.9"); 1/ 设置 图 像 边 框 颜色 
S$graph->SetColor(white’): /设置 图 像 的 填充 颜色 
Sdatas = array("C#", "VB", "VC", "Java", "ASP.NET"): // 设 置 统计 数据 
Sgraph->xaxis->SetTickLabels($datas): 

Sgraph->xaxis->title->Set("Year 2009"): // 设 置 X 轴 标题 
Sgraph->xaxis->title->SetFont(FF_FONTI.FS_BOLD) : // 设 置 标 题字 体 
Sgraph->xaxis->title->SetColor('red): // 设 置 字体 颜色 
Sgraph->xaxis->SetFont(FF_FONT1.FS_BOLD): // 设 置 隐 轴 字 体 
Sgraph->xaxis->SetColor(navy'): // 设 置 X 轴 刻度 线 颜 色 
$graph->yaxis->SetFont(FF_ FONT1.FS_BOLD): /设置 立轴 字体 
S$graph->yaxis->SetColor(navy): 1/ 设置 Y 轴 刻 度 线 颜色 
$egraph->title->Set(iconv("utf-8","gb2312", 公 司 2009 年 第 一 季度 编程 词典 销售 情况 ): /定义 标题 
Sgraph->title->SetFont(FF_SIMSUN. FS_BOLD): // 设 置 标题 字体 
Sgraph->title->SetMargin(3): // 设 置 图 像 距 离 顶 部 距离 
// 创 建 3 个 方 柱 统计 图 
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Sbplotl = new BarPlot($datay1): 
Sbplot2 = new BarPlot($datay2): 
Sbplot3 = new BarPlot($datay3): 


/省 略 了 部 分 代码 
S$bplotl->value->Show0: /输出 图 像 对 应 的 数据 值 
$bplotl->value->SetFont(FF_ARIAL.FS_BOLD): /定义 图 像 值 的 字体 
S$bplot1->value->SetColor("black","darkred"); // 定 义 值 的 颜色 
/省 略 了 部 分 代码 
// 实 例 化 图 像 操作 组 类 
S$gbarplot = new GroupBarPlot(array($bplotl.Sbplot2.Sbplot3)): 
S$gbarplot->SetWidth(0.8): /设置 图 像 大 小 
Sgraph->Add($gbarplot); /添加 数据 
S$graph->Stroke(); /生成 图 像 
、、 
图 秘笈 心 法 


心 法 领悟 293: 图 像 颜色 的 填充 。 
在 JpGraph 类 库 中 ， 应 用 SetFillColor0 方 法 为 图 像 填充 颜色 ;通过 SetColor(0 方 法 定义 数据 、 文 字 、 坐 标 轴 
的 颜色 。 


S | 于 

实例 294 趣味 指数 : 友 友 去 友 妆 : 
力 实例 说 明 

在 本 实例 中 ， 运 用 JpGraph 生成 折线 图 ， 分 析 网 站 一 天 内 的 访问 走势 ， 其 运行 结果 如 图 6.26 所 示 。 

网 站 一 天 内 流量 分 析 
100.0 
EE drat 
图 6.26 网 站 访问 走势 分 析 

力 关键 技术 


在 本 实例 中 ， 以 一 天 的 十 二 个 时 辰 为 单位 ， 分 析 在 这 十 二 个 时 辰 中 网 站 访问 量 的 走势 。 使 用 人 pGraph 类 库 
创建 折线 统计 图 ,除了 需要 在 程序 中 包含 jpgraph.php 文 件 外 ,还 需要 包含 jpgraph_line .php 文件 ,从 而 启用 JpGraph 
类 库 的 折线 创建 功能 。 其 中 使 用 的 卫 Graph 技术 如 下 : 

(1) 使 用 LinePlot 对 象 绘制 曲线 。 
通过 了 Graph 类 库 中 的 LinePlot 类 创建 曲线 ， 该 类 的 语法 如 下 : 


SlinePlot = new LinePlot($data) // 创 建 折线 图 

$data: 数值 型 数组 ， 指 定 统计 数据 。 

(2) SetFont( 方 法 统计 图 标题 、 坐 标 轴 等 文字 样式 。 

制作 统计 图 时 ， 需 要 对 图 像 的 标题 、 坐 标 轴 内 文字 进行 样式 设置 ， 在 了 Graph 类 库 中 ， 可 以 使 用 SetFontO 


方法 实现 ， 该 方法 的 语法 如 下 : 
SetFont($family, [Sstyle.] [$size]) 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


参数 说 明 : 

$family: 指定 文字 的 字体 。 

Sstyle: 指定 文字 的 样式 。 

$size: 指定 文字 的 大 小 ， 默 认为 10。 


(3) SetMargin() 方 法 设置 图 像 、 标 题 、 坐 标 轴 上 文字 与 边框 的 距离 ， 其 语法 如 下 : 


SetMargin(SlefSright Stop.Sbottom) 
参数 指定 其 与 左右 、 上 下 边框 的 距离 。 
或 者 : 

SetMargin(Sdata) 

$data: 指定 与 边框 的 距离 。 


力 设计 过 程 


(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文 件 夹 06 下 的 
JpGraph 文件 。 注 意 本 实例 中 创建 的 是 折线 图 ， 所 以 导入 的 文件 也 发 生 了 变化 。 
(2) 应 用 卫 Graph 类 库 中 的 方法 创建 一 个 折线 图 ， 对 网 站 一 天 内 的 访问 量 走势 进行 分 析 ， 其 关键 代码 


如 下 : 


<?php 

header ( "Content-type: text/html; charset=UTF-8" ); 
include ("../src/jpgraph.php"): 

include ("../src/jpgraph_line.php"); 

// 这 里 省 略 了 创建 数据 的 代码 

Sgraph = new Graph(450,275); 
Sgraph->SetMargin(40,40,40,50); 
Sgraph->SetScale("textint"): 

Sgraph->SetShadow(): 
S$graph->title->Set(iconv("utf-8","gb2312", 网 站 一 天 内 流量 分 析 ")); 
Sgraph->title->SetFont(FF_SIMSUN, FS_BOLD): 
Sgraph->title->SetMargin(10); 
Sgraph->xaxis->SetTickLabels($datas); 
Sgraph->xaxis->SetFont(FF_SIMSUN, FS_BOLD.8); 
Sgraph->xaxis->title->Set("2009-07-21"); 
Sgraph->xaxis->title->SetFont(FF_ARIAL,FS_BOLD): 
Sgraph->xaxis->title->SetMargin(10); 

Spl = new LinePlot($datay): 

S$pl->value->ShowO); 
Spl->value->SetFont(FF_ARIAL.FS_BOLD):; 
S$pl->value->SetColor("black"."darkred"): 
S$pl->SetColor("blue"): 
S$pl->SetFillColor("blue@0.4"): 

Sgraph->Add($pl): 

Sgraph->Stroke(): 


?> 
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// 设 置 文件 编码 格式 


// 创 建 图 像 

// 设 置 图 像 的 边框 

// 定 义 刻度 值 的 类 型 
/设置 图 像 阴影 
/定义 标题 

// 设 置 标题 字 

// 设 置 标题 字 

/添加 X 轴 上 的 数据 
/定义 字体 

/设置 和 轴 的 角 标 
/定义 字体 
/定义 位 置 

// 创 建 折线 图 像 

// 输 出 图 像 对 应 的 数据 值 
// 定 义 图 像 值 的 字体 
// 定 义 值 的 颜色 

// 定 义 图 像 颜色 

// 定 义 填充 颜色 

// 添 加 数据 

// 输 出 图 像 


心 法 领悟 294: 创建 不 同 的 图 像 所 导入 的 文件 是 有 所 区 别 的 。 


如 果 创 建 柱 形 图 ， 那 么 导入 的 文件 是 : 
include ("./sre/ipgraph.php"): 

include ("./sre/ipgraph bar.php"): 

include ("../sre/jpgraph_flags.php"): 

如 果 创 建 折 线 图 ， 那 么 导入 的 文件 是 : 
include ("../sre/ipgraph.php"): 

include (". /sre/jpgraph_line .php"): 


这 点 必须 注意 ， 如 果 没 有 导入 正确 的 文件 ， 就 不 能 完成 图 像 的 创建 操作 。 
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实例 295 


力 实例 说 明 
在 本 实例 中 ， 运 用 JpGraph 实现 柱 形 图 与 折线 图 的 结合 ， 对 2009 年 图 书 销量 和 市 场 占有 率 进行 分 析 ， 其 运 


行 结果 如 图 6.27 所 示 。 


2009 年 图 书 梢 重 和 市 场 占有 地 分 析 


二 sell wantity 


， 
Jan Feb Miar fpr May Jun ul Re Sep Cct 有 


图 6.27 2009 年 图 书 销量 和 市 场 占有 率 分 析 


图 关键 技术 


在 本 实例 中 ,运用 JpGraph 对 2009 年 图 书 销量 和 市 场 占有 率 进 行 分 析 ， 旨 在 介绍 如 何 实现 柱 形 图 与 折线 图 
的 结合 ， 同 时 渗入 一 个 图 像 注 释 的 应 用 。 

柱 形 图 与 折线 图 的 结合 ， 就 是 在 同一 图 像 中 分 别 创建 一 个 柱 形 图 和 一 个 折线 图 ， 与 单独 创建 柱 形 图 和 折线 
图 是 相同 的 ， 唯 一 的 区 别 就 是 要 同时 包含 柱 形 图 文件 和 折线 图 文件 。 

include (". /src/jpgraph.php"): 

include (".,/src/ipgraph line.php"); 

include ("../src/jpgraph_error.php"); 

include ("../src/jpgraph_bar.php"); 

本 实例 中 添加 了 一 个 图 像 注释 ， 通 过 图 像 的 颜色 来 体现 ， 黄 色 ( 柱 形 ) 代表 图 书 销量 数据 ， 蓝 色 〈 折 线 ) 
代表 市 场 占有 率 分 析 数 据 ， 其 具体 的 关键 技术 如 下 : 


在 创建 的 图 像 对 象 中 应 用 SetLegend0 方 法 添加 注释 的 内 容 ， 其 关键 代码 如 下 : 
Sllplot->SetLegend("Sell quantity"): 

其 参数 就 是 指定 要 输出 的 注释 内 容 。 

通过 SetColor0 和 SetFillColor() 方 法 设置 注释 对 应 的 图 像 颜色 。 


国 设计 过 程 
(1) 创建 ndex.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 
区 Graph 文件 。 注 意 本 实例 中 要 导入 的 文件 包括 折线 图 和 柱 形 图 两 种 。 


(2) 应 用 七 Graph 类 库 中 的 方法 在 同一 图 像 中 创建 一 个 柱 形 图 和 一 个 折线 图 ， 完 成 对 图 书 销量 和 市 场 占有 


率 的 分 析 ， 其 关键 代码 如 下 : 
<?php 
header ( "Content-type: text/html: charset=UTF-8" ): /设置 文件 编码 格式 
include ("./sre/ipgraph. php 


Co 
include (". /sre/ipgraph_bar.php"): 

Slldatay = array(11.9.2.4.3,13,17.23.12.5.19.17): 

Sl2datay = amray(23.12.5.19.17.10.15.11.9.2.4.3): 
Sdatax=array("Jan"."Feb"."Mar"."Apr"."May"."Jan"."Jul"."Aug"."Sep"."Oct"."Nov"."Dec"); 
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Sgraph = new Graph(450,275,"auto"): // 创 建 图 像 
Sgraph->img->SetMargin(40,70,20.40); /定义 图 像 边 距 
Sgraph->SetScale("textlin"); // 定 义 刻度 类 型 
Seraph->SetColor(array(250,250.250)); // 定 义 颜色 
S$llplot=new LinePlot($l1datay); // 创 建 图 像 
S$llplot->SetColor("blue"); // 设 置 图 像 颜 色 
Sllplot->SetWeight(2); /设置 折线 宽度 
S$llplot->SetLegend("Sell quantity"); 
Sl2plot = new BarPlot($l2datay); /创建 图 像 
$l2plot->SetFilColor("orange"); /图 像 填充 颜色 
S$l2plot->SetLegend("Market share"); /| 输出 注释 内 容 
Sgraph->Add($l1plot); // 向 图 像 中 添加 数据 
Sgraph->Add($L2plot); // 向 图 像 中 添加 数据 
$egraph->title->Set(iconv("utf-8","gb2312","2009 年 图 书 销量 和 市 场 占有 率 分 析 ")); // 定 义 标题 
Sgraph->xaxis->title->Set("Month"); /定义 科 轴 角 标 
S$graph->yaxis->title->Set(iconv("utf-8","gb2312"," 单 位 。〔 万 册 》")); /定义 立轴 标题 
Sgraph->title->SetFont(FF_SIMSUN. FS_BOLD): /定义 字体 
$graph->yaxis->title->SetFont(FF_SIMSUN, FS_BOLD); /定义 字体 
$graph->xaxis->title->SetFont(FF_SIMSUN, FS_BOLD); /定义 字体 
Sgraph->xaxis->SetTickLabels($datax); /| 定义 义 轴 标题 
S$graph->Stroke(); // 生 成 图 像 
> 
MS 
力 秘笈 心 法 


心 法 领悟 295: 通过 SetWeight0 方 法 设置 折线 图 折线 的 宽度 。 


在 人 pGraph 类 库 中 创建 折线 图 时 ， 可 以 通过 SetWeight() 方 法 设置 折线 图 折线 的 宽度 ， 其 语法 如 下 ; 
S$llplot->SetWeight($data); /设置 折线 宽度 


$llplot 指 创建 折线 图 返回 的 对 象 ，$data 是 折线 图 折线 的 宽度 值 。 


高 级 | 
实例 

实例 296 起 味 指数 : loon 

实例 说 明 
在 本 实例 中 , 运用 JpGraph 生成 折线 图 , 对 2009 年 牛肉 市 场 的 价格 走势 进行 分 析 , 其 运行 结果 如 图 6.28 所 示 。 

2009 年 牛肉 而 场 的 价格 分 本 
$20,.0 
6.28 ”2009 年 牛肉 市 场 价格 走势 分 析 
图 关键 技术 


在 本 实例 中 ， 通 过 JpGraph 类 库 创建 折线 图 ， 分析 2009 年 牛肉 市 场 的 价格 走势 ， 旨 在 突出 如 何在 折线 图 中 
输出 格式 化 的 数据 ， 以 及 在 折线 图 的 数据 点 上 添加 标记 。 
(1) 输出 数据 应 用 的 是 value0 对 象 中 的 Show( 方 法 ， 数 据 的 格式 化 应 用 的 是 SetFormat0 方 法 。 


SetFormat($aFormat SaNegFormat) 
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参数 说 明 : 

$aFormat: 设置 格式 化 的 样式 。 

$aNegFormat: 设置 negative 的 值 。 

(2) 折线 图 中 标记 的 添加 应 用 的 是 图 像 mark 对 象 中 的 SetType0 方 法 ， 其 参数 值 用 于 设置 标记 的 类 型 ， 语 
A SaFileName, $aScale) 

参数 说 明 : 

$aType: 设置 标记 的 类 型 。 

$aFileName: 插入 图 像 的 名 称 或 者 国家 的 名 称 。 

$aScale: 设置 插入 标记 的 大 小 。 

其 中 ，$aType 的 可 选 类 型 包括 MARK_SQUARE、 MARK UTRIANGLE、 MARK _DTRIANGLE、 MARK_ 
DIAMOND、MARK_CIRCLE， 这 些 标记 仅 供 参 考 ， 如 果 想 了 解 更 多 内 容 ， 请 参考 JpGraph 类 库 的 参考 手册 。 


国 设计 过 程 


(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 
JpGraph 文件 。 
(2) 应 用 卫 Graph 类 库 中 的 方法 创建 一 个 折线 图 ， 对 2009 lb 其 代码 如 下 : 


Sydata = array(12,18,15,17,16,20,17,13,15,17,15,16); // 定 义 数 
Sgraph = new Graph(450,300,"auto"); 人 
Sgraph->SetScale("textlin"); // 定 义 刻 度 值 类 型 
Sgraph->img->SetMargin(50,40,40,55); // 设 置 边 框 的 间距 
Slineplot=new LinePlot($ydata): // 创 建 折线 图 
$lineplot->mark->SetType(MARK_UTRIANGLE): /定义 折线 图 的 标记 点 
Slineplot->value->show(); // 输 出 折线 图 对 应 的 值 
Slineplot->value->SetColor('darkred'); /设置 值 的 颜色 
Slineplot->value->SetFont(FF_FONTI1.FS_BOLD): 1/ 设置 值 的 字体 
S$lineplot->value->SetFormat('$%0.1f); // 对 值 进行 格式 化 
S$graph->Add($lineplob; // 添 加 数据 
S$graph->title->Set(iconv("utf-8","gb2312","2009 年 牛肉 市 场 的 价格 分 析 ")); // 定 义 标题 
S$graph->xaxis->title->Set(iconv("utf-8","gb2312"," 单 位 ， 元 /月 份 ")); // 定 义 义 轴 输出 的 值 
Sgraph->xaxis->title->SetMargin(10): // 定 义 义 轴 输出 的 值 
Sgraph->title->SetFont(FF_SIMSUN. FS_BOLD): // 设 置 标题 字体 
Sgraph->yaxis->title->SetFont(FF_SIMSUN, FS_BOLD):; // 设 置 Y 轴 内 容 的 字体 
Sgraph->xaxis->title->SetFont(FF_SIMSUN, FS_BOLD): 1/ 设置 X 轴 内 容 的 字体 
S$lineplot->SetColor("blue"); 1/ 设置 图 像 颜色 
Slineplot->SetWeight(2); /设置 折线 的 宽度 
Sgraph->Stroke(); // 生 成 图 像 
?> 

图 秘笈 心 法 


心 法 领悟 296: 在 JpGraph 类 库 中 字体 的 选择 。 
在 JpGraph 类 库 中 ， 可 以 设置 的 字体 很 多 。 但 是 在 选择 字体 时 必须 注意 ， 有 些 字体 是 不 支持 中 文 的 。 


实例 297 


趣味 指数 : lololole, 


力 实例 说 明 
在 本 实例 中 ， 运 用 JpGraph 生成 折线 图 ， 对 公司 2009 年 的 销售 额 进行 分 析 ， 其 运行 结果 如 图 6.29 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 
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图 6.29 2009 年 公司 的 销售 额 


图 关键 技术 


在 本 实例 中 ， 通 过 JpGraph 类 库 创建 折线 图 ， 分 析 2009 年 公司 的 销售 额 ， 旨 在 突出 如 何在 折线 图 中 通过 插 


入 的 图 像 设置 数据 点 标签 。 


实例 296 中 运行 SetType0 方 法 的 第 1 个 参数 ， 直 接 设置 标签 的 样式 ,在 本 实例 中 ,运用 SetType0 方 法 的 第 
2 个 参数 , 通过 插入 的 图 像 设置 数据 点 的 标签 , 并 通过 第 3 个 参数 设置 插入 图 像 的 大 小 , 其 语法 请 参考 实例 296。 


力 设计 过 程 


(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 


JpGraph 文件 。 


(2) 应 用 卫 Graph 类 库 中 的 方法 创建 一 个 折线 图 ， 对 2009 年 公司 的 销售 额 进行 分 析 ， 其 代码 如 下 : 


Sdatayl = array(40.26.15.35.26.15.44.26.15.27.40.15); 
Sgraph =new Graph(650,375); 
Sgraph->SetMarginColor("white); 
Sgraph->SetScale("textlin"); 
Sgraph->SetFrame(false); 
Sgraph->SetMargin(30,5,35,20); 


S$graph->tabtitle->Set(iconv("utf-8","gb2312",2009 年 销售 额 分 析 ) ): 


Sgraph->tabtitle->SetFont(FF_SIMSUN, FS_BOLD.12): 
Sgraph->tabtitle->SetColor('darkred',#E1E1FF); 
Sgraph->xgrid->Show(); 
Sgraph->xaxis->SetTickLabels($gDateLocale->GetShort MonthO): 
S$pl = new LinePlot(Sdatay1): 

S$pl->SetColor(navy"); 
S$pl->mark->SetType(MARK_IMG,saab_95jpg,0.5); 
S$pl->value->SetFormat(%d "iconv("utf-8","gb2312",' 万 元 ); 
S$pl->value->Show(): 

S$pl->value->SetColor('darkred); 
S$pl->value->SetFont(FF_SIMSUN, FS_BOLD,10); 
Spl->value->SetMargin(14): 

S$p1->SetCenter(): 

Sgraph->Add($p1): 

Sgraph->Stroke(); 


国 秘笈 心 法 


/定义 图 像 大 小 
/背景 颜色 
/定义 刻度 值 类 型 


/设置 边 距 

/| 输出 标题 

1/ 设置 标题 字体 

// 设 置 标题 颜色 

/设置 阴影 

/定义 和 X 轴 上 的 数据 

1/ 创建 图 像 

// 设 置 图 像 颜色 

1/ 设置 标签 的 样式 ， 使 用 图 片 
/格式 化 数据 

/输出 阴影 

/定义 颜色 

/设置 字体 

/设置 字体 大 小 、 位 置 


/添加 数据 
// 生 成 图 像 


心 法 领 司 297: 在 了 Graph 类 库 中 通过 旗帜 来 设置 数据 点 的 标签 。 
通过 旗帜 设置 数据 点 的 标签 ， 同 样 应 用 SetType0 方 法 ， 只 是 需要 将 第 1 个 参数 设置 为 MARK FLAG 系列 
(1、2、3、4 表示 旗帜 的 大 小 不 同 ) ， 然 后 将 第 2 个 参数 设置 为 对 应 旗帜 的 表示 即 可 。 
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| 
趣味 指教: 页 丰 本 丰 ; 
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图 实例 说 明 
在 本 实例 中 ， 运 用 JpGraph 生成 柱 形 图 ， 对 编程 词典 的 销售 比例 进行 分 析 ， 其 运行 结果 如 图 6.30 所 示 。 
编程 记 销售 比 例 分 析 
SP TO PD 
“i 
"i 
= ll 
图 6.30 编程 词典 销售 比例 分 析 
图 关键 技术 


在 本 实例 中 ， 通 过 Graph 类 库 创建 柱 形 图 ， 分 析 编 程 词典 的 销售 比例 。 本 实例 中 再 次 创建 柱 形 图 ， 与 以 
往 的 有 些 不 同 ， 这 里 将 柱 形 图 顺 时针 旋 转 了 90”。 


主要 应 用 图 像 对 象 中 的 Set90AndMargin0 方 法 ， 完 成 柱 形 图 的 顺 时 针 90” 旋 转 ， 其 语法 如 下 : 
Set90AndMargin($Im, Sm. Stm, $bm) 


参数 说 明 : 

$lm: 左边 框 旋转 角度 。 
Srm; 右边 框 旋转 角度 。 
$tm: 上 边框 旋转 角度 。 
$bm: 下 边框 旋转 角度 。 


力 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 inelude0 语 句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 


Jpgraph 文件 。 
(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 柱 形 图 ， 从 另外 一 个 角度 分 析 编 程 词典 的 销售 比例 ， 其 代码 如 下 : 


S$datayr-array(70.50.85.120.50): 
Sdatax=array("VB"."VC","Java"."C#"."ASP NET"): 


S$width=500; // 定 义 图 像 宽 
Sheight=600: // 定 义 图 像 高 
Sgraph = new Graph($width.S$height.'auto): /| 创建 图 像 


S$graph->SetScale("textlin"); /定义 刻度 值 类 型 
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Sright = 50: 
Sgraph->Set90AndMargin(Sleft. Sright, Stop.Sbotton): 


S$graph->title->Set(iconv("utf-8","gb2312"." 编 程 词典 销售 比例 分 析 ")); 


Sgraph->title->SetFont(FF_SIMSUN. FS_BOLD,14): 
Sgraph->subtitle->Set("(2009-06)"):; 
Sgraph->xaxis->SetTickLabels($datax): 
Sgraph->xaxis->SetFont(FF_VERDANA.FS_NORMAL.12); 
Sgraph->xaxis->SetLabelAlign('right','center); 
Sgraph->yaxis->scale->SetGrace(20); 
Sgraph->yaxis->SetLabelAlign('center ,bottom); 
Sgraph->yaxis->SetLabelAngle(45); 
Sgraph->yaxis->SetLabelFormat(%d'): 
Segraph->yaxis->SetFont(FF VERDANA.FS_ NORMAL.12): 
Sbplot = new BarPlot($datay): 
$bplot->SetFillColor("orange"); 

S$bplot->SetShadow(); 

Sbplot->value->Show(); 
S$bplot->value->SetFont(FF_ARIAL.FS_BOLD.12); 
S$bplot->value->SetAlign('left','center); 
Sbplot->value->SetColor("black","darkred"); 
S$bplot->value->SetFormat(%.1f); 

Sgraph->Add($bplot); 

Sgraph->Stroke():; 


国 秘笈 心 法 


/设置 图 像 的 边 距 

/定义 标题 

/设置 标题 字体 

/设置 副标题 

/定义 义 轴 上 的 数据 

/设置 字体 

// 设 置 Y 轴 上 字体 右 侧 居 中 
// 设 置 Y 轴 间距 

// 设 置 Y 轴 字体 居中 ， 底 部 对 齐 
// 设 置 字体 的 倾斜 度 

/输出 数据 的 格式 

/设置 字体 


像 
/设置 图 像 阴影 
/设置 数据 阴影 
/设置 数据 字体 
// 设 置 数据 位 置 
/设置 数据 颜色 
/格式 化 数据 
// 添 加 数据 
/生成 图 像 


心 法 领悟 298: 在 卫 Graph 类 库 中 控制 坐标 轴 上 标签 的 位 置 。 
在 JpGraph 类 库 中 , 控制 坐标 轴 上 标签 的 位 置 应 用 的 是 SetLabelAlign0 方 法 , 在 本 实例 中 多 次 使 用 了 这 个 方 


法 ， 完 成 对 数据 在 边框 和 坐标 上 位 置 的 控制 。 


实例 299 


力 实例 说 明 


趣味 指数 : abodedobad 


在 本 实例 中 ， 运 用 JpGraph 生成 饼 形 图 ， 对 公司 年 度 图 书 销量 情况 进行 分 析 ， 其 运行 结果 如 图 6.31 所 示 。 
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图 6.31 2009 年 图 书 销量 分 析 


图 关键 技术 


在 本 实例 中 ， 通 过 了 pGraph 类 库 创 建 饼 形 图 ， 分 析 2009 年 图 书 销量 情况 ， 旨 在 突出 饼 形 图 的 创建 方法 ， 其 


应 用 的 关键 技术 如 下 : 


(1) 创建 饼 形 图 图 像 应 用 PieGraph 类 ， 该 类 继承 Graph 类 ， 创 建 3D 饼 形 图 的 图 像 。 
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(2) 创建 3D 饼 形 图 应 用 PiePlot3D 类 ， 该 类 继承 PiePlot 类 。 
(3) 通过 图 像 中 的 legend 对 象 调用 Pos0 方 法 定位 饼 形 图 在 图 像 中 的 存储 位 置 。Pos0 方 法 的 语法 如 下 : 
Pos($aX, $aY, SaHAlign, $aVAlign) 
参数 说 明 : 
$aX: 设置 距离 X 轴 的 位 置 。 
$aY: 设置 距离 了 轴 的 位 置 。 
$aHAlign: 设置 右 侧 〈 居 中 、 居 左 或 者 居 右 ) 。 
$aVAlign: 设置 顶部 〈 居 下 、 居 上 或 者 居中 ) 。 
(4) 通过 饼 形 图 对 象 调用 SetTheme() 方 法 设置 饼 形 图 的 颜色 。SetTheme() 方 法 的 语法 如 下 : 
人 


参数 $aTheme 指定 主题 的 名 称 ， 其 支持 的 主题 包括 earth、pastel、sand 和 water。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 
JpGraph 文件 。 
(2) 应 用 了 Graph 类 库 中 的 方法 创建 一 个 饼 形 图 ， 对 2009 图 书 销量 进行 分 析 ， 其 代码 如 下 : 
< 
2 "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
include (".,/sre/jpgraph.php"): 
include ("../src/jpgraph_pie.php"); 


include ("./src/jpgraph_pie3d.php"); 
Sdata = array(20.27.45.75.90.30); 


S$graph = new PieGraph(500,275,"auto"); // 创 建 图 像 
Sgraph->SetShadow(); // 输 出 阴影 
S$graph->tabtitle->Set(iconv("utf-8","gb2312",'2009 年 图 书 销售 分 析 ) ); /输出 标题 
Sgraph->tabtitle->SetFont(FF_SIMSUN, FS_BOLD.18): // 设 置 标题 字体 
Sgraph->title->SetColor("darkblue"); /定义 标题 颜色 
S$graph->legend->Pos(0.1.0.2); // 控 制 注释 文字 的 位 置 
S$pl = new PiePlot3d($data); /创建 3D 饼 形 图 图 像 
Spl->SetTheme("water"); 1/ 控制 图 像 颜色 的 主题 
S$pl1->SetCenter(0.35); /控制 图像 的 大 小 比例 
$p1->SetAngle(30); // 控 制图 像 的 倾斜 角度 
Spl->value->SetFont(FF_ARIAL.FS_NORMAL.12); /设置 字体 
S$pl->SetLegends(array("ASP.NET","C#","Java","PHP"."VB"."VC")); 
Sgraph->Add($p1): // 添 加 数据 
S$graph->Stroke(); /生成 图 像 
?> 
,~ 
图 秘笈 心 法 


心 法 领悟 299: 在 JpGraph 类 库 中 控制 饼 形 图 大 小 和 倾斜 角度 的 方法 。 
在 了 pGraph 类 库 中 ， 通 过 饼 形 图 对 象 中 的 SetCenter0 方 法 控制 饼 形 图 的 大 小 比例 ， 默 认 值 是 0.5; 通过 
SetAngle0 方 法 控制 图 像 的 倾斜 角度 ， 倾 斜 角度 必须 在 10” ~ 80” 之 间 。 


. 程 词典 销售 比例 | 
实例 300 二 oie 
实例 说 明 


在 本 实例 中 , 运用 JpGraph 生成 饼 形 图 , 对 公司 各 语言 编程 词典 的 销售 比例 进行 分 析 , 其 运行 结果 如 图 6.32 
所 示 。 
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编程 词典 铺 售 比例 分 析 


图 6.32 编程 词典 销售 比例 


图 关键 技术 


在 本 实例 中 ， 通 过 JpGraph 类 库 创 建 饼 形 图 ， 分 析 2009 年 各 语言 编程 词典 的 销售 比例 ， 旨 在 突出 饼 形 图 的 
创建 方法 ， 其 应 用 的 关键 技术 如 下 : 
(1) 创建 饼 形 图 图 像 应 用 PieGraph 类 ， 该 类 继承 Graph 类 ， 创 建 3D 饼 形 图 的 图 像 。 
(2) 创建 3D 饼 形 图 应 用 PiePlot3D 类 ， 该 类 继承 PiePlot 类 。 
(3) 通过 ExplodeSlice0 方 法 对 饼 形 图 进行 分 割 ， 其 语法 如 下 : 


ExplodeSlice(Se, Sradius) 
参数 说 明 : 

$e: 指定 分 割 的 区 块 ; 

Sradius: 指定 分 割 的 区 块 与 原 图 的 距离 。 


力 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 


JpGraph 文件 。 
(2) 应 用 JpGraph 类 库 中 的 方法 创建 一 个 饼 形 图 ， 对 2009 年 各 语言 编程 词典 的 销量 进行 分 析 ， 其 代 


码 如 下 : 
<?php 
header ( "Content-type: text/html; charset=UTF-8" ); 1/ 设置 文件 编码 格式 
include ("../sre/jpgraph.php"); 
include ("../sre/jpgraph_pie.php"): 
include (".,/sre/jpgraph_pie3d.php"); 
Sdata = array(20.15.30.30.15); 
$datas = array("C#", "VB", "VC", "Java", "ASP.NET"): 1/ 设置 统计 数据 
Sgraph = new PieGraph(450,240.,"auto"); // 创 建 图 像 
Sgraph->SetShadow(); // 创 建 图 像 明 影 
Sgraph->title->Set(iconv("utf-8","gb2312"," 编 程 词典 销售 比例 分 析 ")); /定义 标题 
Sgraph->title->SetFont(FF_SIMSUN. FS_BOLD): // 设 置 标题 字体 
$pl =new PiePlot3D($data): // 生 成 饼 形 图 
S$p1->ExplodeSlice(4.50): /设置 饼 形 图 分 割 位 置 
S$pl->SetCenter(0.35); // 设 置 饼 形 图 在 图 像 中 的 存储 位 置 
S$pl->SetLegends($datas): // 设 置 说 明文 字 的 内 容 
Seraph->Add($p1); // 添 加 数据 
S$graph->Stroke(; // 生 成 图 像 
?> 

图 秘笈 心 法 


心 法 领悟 300: 如 何 保持 3D 饼 形 图 的 完整 性 。 


在 了 Graph 类 库 中 创建 3D 饼 形 图 时 ， 如 果 不 应 用 ExplodeSlice0 方 法 ， 那 么 创建 的 3D 饼 形 图 就 是 完整 的 ; 
如 果 应 用 Explode0 方 法 ， 将 一 个 数组 值 作为 参数 ， 那 么 就 可 以 实现 3D 饼 形 图 的 多 块 分 割 。 
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新 2009 年 图 书 销量 高 级 | 


趣味 指数 ， 寞 太 二 宙 从 


D0 dro v0 Ovon oodno eerivv ordered 


实例 301 


力 实例 说 明 
在 本 实例 中 , 运用 JpGraph 生成 多 饼 形 图 区 块 , 对 公司 2009 年 图 书 销量 进行 分 析 , 其 运行 结果 如 图 6.33 所 示 。 


国 口 品 日 口 目 


图 6.33 ”2009 年 图 书 销量 分 析 


图 关键 技术 


在 本 实例 中 ,通过 Jpgraph 类 库 创建 饼 形 图 ， 应 用 饼 形 图 对 象 中 的 Explode0 方 法 完成 对 2009 年 图 书 销量 的 
分 块 展示 。Explode0 方 法 的 语法 如 下 : 

Explode($aExplodeArr) 

该 方法 将 饼 形 图 分 割 成 多 个 模块 ， 参 数 $aExplodeArr 是 一 个 数组 ， 根 据 数 组 元 素 个 数 定义 分 割 数 量 ， 根 据 
数组 元 素 值 定义 分 割 后 模块 与 原 图 像 的 距离 。 


力 设计 过 程 

(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 
JpGraph 文件 。 

(2) 应 用 卫 Graph 类 库 中 的 方法 创建 一 个 饼 形 图 ， 对 2009 年 图 书 销量 进行 分 析 ， 其 代码 如 下 : 

oo "Content-type: text/html; charset=UTF-8" ): /设置 文件 编码 格式 


include (". /src/ipgraph.php"); 
include (". /src/jpgraph_pie.php"); 

include ("./src/ipgraph pie3d.php"); 
Sdata = array(20,27.45.75.90,3( 


Sgraph = new PieGraph($500.245."auto"); // 创 建 图 像 
Sgraph->SetShadow(): // 创 建 图 像 阴 影 
S$graph->tabtitle->Set(iconv("utf-8"."gb2312",2009 年 图 书 销售 分 析 ") ); /| 输出 标题 
Sgraph->tabtitle->SetFont(FF_SIMSUN. FS_BOLD.14): /设置 标题 字体 
S$graph->title->SetColor("darkblue"): /定义 标题 颜色 
S$graph->legend->Pos(0.1.0.2): // 控 制 注释 文字 的 位 置 
S$pl = new PiePlot3d($data): // 创 建 图 像 
S$pl->SetTheme("sand"): // 控 制图 像 颜色 
S$pl->SetCenter(0.4); /设置 图 像 位 置 
S$pl->SetSize(0.4): // 设 置 图 像 大 小 
$pl->SetHeight(20): // 设 置 饼 形 图 高 度 
$p1->SetAngle(45): /设置 图 像 倾斜 角度 
$p1->Explode(array(5.40.10.30.20)): /控制 饼 形 图 的 分 割 
$p1->value->SetFont(FF_ARIALFS_NORMAL.10): /设置 字体 
Spl->SetLegends(array("ASP.NET"."C#"."Java","PHP"."VB"."VC")): 

S$eraph->Add($p1): // 添 加 数据 
Sgraph->Stroke(); // 生 成 图 像 

Se 
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心 法 领悟 301: 设置 3D 饼 形 图 的 高 度 。 
在 JpGraph 类 库 中 设置 3D 饼 形 图 的 高 度 ， 应 用 饼 形 图 对 象 中 的 SetHeight0 方 法 。 


力 实例 说 明 


在 本 实例 中 ,运用 名 Graph 类 库 在 同一 图 像 中 生成 多 个 饼 形 图 ， 对 公司 2009 年 上 半年 编程 词典 销量 进行 分 
析 ， 其 运行 结果 如 图 6.34 所 示 。 


趣味 指数 : 让 页 宙 走穴 


图 6.34 2009 年 上 半年 编程 词典 销量 分 析 


图 关键 技术 


在 本 实例 中 ， 通 过 JpGraph 类 库 创建 多 饼 形 图 ， 其 实现 的 关键 是 数组 和 for 循环 语句 的 运用 。 饼 形 图 创建 的 
原理 与 前 面 介绍 的 相同 ， 只 是 这 里 根据 传递 的 数组 数据 对 饼 形 图 的 创建 方法 执行 了 循环 操作 ， 从 而 完成 多 饼 形 
图 的 创建 。 

其 中 关键 的 内 容 就 是 输出 的 数据 、 饼 形 图 的 坐标 定义 和 饼 形 图 标题 的 设置 ， 根 据 这 3 个 数组 数据 ， 然 后 执 


行 for 循环 ， 完 成 饼 形 图 的 创建 ， 其 关键 代码 如 下 : 
$data = array( // 定 义 输出 的 数据 
array(80.18,15.17.50.90). 
array(35.90.70.34.60.120). 
armray(40.68.70.50.80.100), 
array(60.22.80.40.100.90)): 
S$piepos = array(0.2.0.4.0.65.0.28.0.25.0.75.0.8.0.75): /定义 饼 形 图 的 坐标 
Stitles = array(Ct JAVA'VB VC)): /定义 标题 
$n = count($picpos)/2: /统计 饼 形 图 的 个 数 


转 设计 过 程 
(1) 创建 ndex php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 


Jpgraph 文件 。 
(2) 根据 定义 的 坐标 值 数 组 计算 出 饼 形 图 的 个 数 ， 应 用 卫 Graph 类 库 中 的 方法 ， 通 过 for 循环 创建 多 个 饼 
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形 图 ， 其 代码 如 下 


Sgraph = new PieGraph(650.500,'auto): // 创 建 图 像 
Sgraph->SetMargin(1.1,40,1); // 定 义 图 像 的 边 距 
Sgraph->SetMarginColor(navy’); /定义 边 距 的 颜色 
Sgraph->SetShadow(false); 


Sgraph->SetBackgroundImage("worldmap1.jpg'.BGIMG FILLPLOT): // 添 加 背景 图 像 
S$graph->title->Set(iconv("utf-8","gb2312",'2009 年 上 半年 编程 词典 销售 分 析 )); 
Sgraph->title->SetFont(FF_SIMSUN, FS_BOLD,18); 


Sgraph->title->SetColor(white’); 

S$p =array0: // 定 义 空 数组 

for( $i=0; $i< $n; ++$i) { // 根 据 饼 形 图 的 个 数 
$d = "data$i"; 
S$p[] = new PiePlot3D($data[$i]); // 创 建 3D 饼 形 图 

} 

for( $i=0; $i< $n; ++$i) { 
Sp[$i]->SetCenter($piepos[2*$i],$piepos[2*$i+1]); // 定 义 饼 形 图 的 位 置 

} 

for( $i=0; $i < $n; ++$1) { /循环 输出 饼 形 图 的 标题 
Sp[$i]->title->Set(Stitles[$i]): /| 输出 标题 
Sp[$i]->title->SetColor(white’); /定义 颜色 
S$p[$i]->title->SetFont(FF_ARIAL,FS_BOLD.10); // 定 义 字 体 

} 

for( $i=0; Si< $n; ++$i) { /循环 读 取 饼 形 图 的 数据 
S$p[$i]->value->SetFont(FF_ARIAL,FS_BOLD); // 定 义 字 体 
Sp[$i]->value->SetColor('white); /定义 颜色 

} 

for( $i=0; $i < Sn; ++$i) { /设置 数据 的 输出 阴影 
Sp[$i]->value->ShowO; 

for( $i=0; $i < $n; ++$i) { // 定 义 输出 数据 的 格式 
Sp[$i]->value->SetFormat("%601.1f9%9"); /| 数据 的 格式 化 

} 

for( Si=0: $i< $n; ++$i) { // 定 义 图 像 大 小 
Sp[$i]->SetSize(0.15); 

} 

for( $i=0; $i < $n; ++$1) { // 定 义 分 割 的 饼 形 图 块 
Sp[$i]->SetEdge(false); 
Sp[$i]->ExplodeSlice(5); 

} 

S$p[0]->SetLegends(array("Jan","Feb","Mar","Apr"."May"."Jun")); // 定 义 注释 内 容 

Sgraph->legend->Pos(0.05.0.35); // 定 义 注释 的 坐标 

Sgraph->legend->SetShadow(false): 

for( $i=0; $i < Sn; ++$i) { 1/ 循环 执行 饼 形 图 数据 的 添加 操作 
Sgraph->Add($p[$i]); 

} 

$egraph->StrokeO; // 生 成 图 像 


国 秘笈 心 法 


心 法 领悟 302: 同一 图 像 中 多 饼 形 图 的 创建 。 

在 同一 图 像 中 创建 多 个 饼 形 图 的 关键 是 如 何 完成 数据 的 循环 读 取 ， 只 要 能 够 准确 地 定位 每 个 饼 形 图 在 图 
像 中 的 位 置 ， 并 且 执行 正确 的 循环 操作 ， 那 么 多 饼 形 图 的 创建 就 不 是 问题 ， 至 于 创建 的 方法 与 单个 饼 形 图 是 相 
同 的 。 


| 


{ 
: 


实例 303 


趣味 指数 : 广 食 三 广 个 


力 实例 说 明 
在 本 实例 中 , 运用 功 Graph 类 库 生成 环 饼 形 图 , 对 公司 2009 年 图 书 销量 进行 分 析 , 其 运行 结果 如 图 635 所 示 。 
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图 6.35 2009 年 图 书 销量 分 析 


图 关键 技术 


在 本 实例 中 ， 通 过 JpGraph 类 库 创建 环 饼 形 图 ， 对 2009 年 各 部 门 图 书 销量 进行 分 析 ， 并 且 通 过 创建 的 文本 
输出 说 明 信 息 ， 其 应 用 的 关键 技术 如 下 : 
(1) 通过 PiePlotC 类 创建 环 饼 形 图 图 像 ， 该 类 继承 PiePlot 类 。 
(2) 通过 环 饼 形 图 中 的 midtitle 对 象 调用 Set0 方 法 输出 环 饼 形 图 的 中 心 标题 ， 调 用 SetFont() 方 法 设置 中 心 
标题 的 字体 。 
(3) 通过 Text 类 在 图 像 中 定义 文本 ， 其 参数 为 向 文本 中 添加 的 数据 。 
图 设计 过 程 
(1) 创建 ndex.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include 语句 导入 所 需 的 存储 在 章 文件 夹 06 下 的 
JpGraph 文件 。 
(2) 应 用 JpGraph 类 库 中 的 方法 创建 一 个 环 饼 形 图 ， 对 2009 年 图 书 销量 进行 分 析 ， 并 通过 文本 输出 说 明 
信息 ， 其 代码 如 下 : 
<7 
> ("Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
include ("../sre/jpgraph.php"); 


include (".,/sre/jpgraph_pie.php"); 
Sdata = array(50,28,25.27,31,20); 


Sgraph = new PieGraph(400.400): // 创 建 图 像 
S$graph->title->Set(iconv("utf-8"."gb2312",2009 年 图 书 销售 分 析 )): // 设 置 标题 文字 
S$graph->title->SetFont(FF_SIMSUN, FS_BOLD.18): // 设 置 字体 
Sgraph->title->SetMargin(8): /设置 边 距 
S$pl = new PiePlotC($data); /创建 图 像 
$p1->SetSize(0.32): // 设 置 图 像 大 小 
$p1->SetCenter(0.5.0.45): /定义 图 像 存储 位 置 
S$pl->value->SetFont(FF_ARIAL.FS_BOLD.12): /设置 数据 的 字体 
S$pl->value->SetColor(‘white); // 设 置 字体 颜色 
$p1->midtitle->Set(iconv("utf-8"."gb2312"," 明 日 科技 ")); /| 输出 中 心 内 容 
S$pl->midtitle->SetFont(FF_SIMSUN. FS_BOLD.14): // 设 置 字体 
S$pl1->SetMidColor('yellow'); 1/ 设置 中 心 图 像 颜色 
Slbl = array("ASP.NET\n%.1196%"."CAn%.1896%","Java\n%%. 1f94%", 

"PHP\n%.1f9%%","VB\n%.1f96%","VC ne.1f94%"); // 定 义 数 据 内 容 
Sp1->SetLabels($IbD): 
$pl->SetShadow0: /生成 阴影 
$p1->ExplodeAll(20): /定义 图 像 大 小 
S$txt= new Text(iconv("utf-8","gb2312","2009 年 各 语言 出 版 图 书 所 占 市 场 份额 ")): // 创 建文 本 并 添加 数据 
S$txt->SetFont(FF SIMSUN, FS BOLD.12): 
S$txt->Pos(0.5.0.97.centervbottom'): // 设 置 存储 位 置 
Stxt->SetBox('yellow','black’): // 设 置 颜色 
Stxt->SetShadow(); // 设 置 图 像 阴 影 
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Seraph->AddText($txt); /添加 数据 
Sgraph->Add($p1); // 向 图 像 中 添加 数据 
Sgraph->StrokeCSIMO; // 生 成 图 像 

> 

秘笈 心 法 


心 法 领悟 303: JpGraph 类 库 的 应 用 总 结 。 

在 6.3 节 的 实例 中 , 笔者 对 了 Graph 类 库 中 常用 的 图 像 创建 方法 进行 了 讲解 。 由 于 笔者 的 水 平 有 限 ,在 讲解 
过 程 中 难免 有 疏漏 之 处 ， 请 读者 见谅 。 

最 后 ， 教 大 家 一 个 学 习 和 运用 JpGraph 类 库 的 好 方法 。 读 者 在 下 载 IpGraph 类 库 时 ， 在 下 载 的 文件 中 包含 
一 个 docportal 文件 夹 ， 在 这 个 文件 夹 中 存储 了 于 Graph 类 库 中 方法 、 对 象 和 类 的 详细 说 明 ， 读 者 如 果 有 不 明之 
处 可 以 在 这 个 参考 手册 中 寻找 答案 。 另 外 ， 在 下 载 的 src 文件 夹 中 ， 还 包含 了 一 个 Examples 文件 夹 ， 在 这 个 文 
件 夹 中 存储 了 很 多 了 Graph 类 库 创 建 图 像 的 实例 ， 读 者 可 以 根据 自己 的 需求 进行 选择 。 


6.4 GD2 函数 库 


GD2 函数 库 在 图 像 图 形 绘制 方面 功能 非常 强大 ， 开 发 人 员 既 可 以 在 已 有 图 片 的 基础 上 进行 绘制 ， 也 可 以 在 
没有 任何 素材 的 基础 上 绘制 。 


中 级 | 


实例 304 趣味 指数 : 妇女 女 商 | 


力 实例 说 明 


应 用 GD2 函数 可 以 绘制 的 图 形 有 多 种 ， 最 基本 的 图 形 包 括 线条 、 圆 、 方 形 等 ， 无 论 开 发 人 员 绘制 多 么 复杂 
的 图 形 ， 都 是 在 这 些 最 基本 的 图 形 基础 上 进行 深化 的 ， 只 有 掌握 了 最 基本 图 形 的 绘制 方法 ， 才 能 绘制 出 各 种 具 
有 独特 风格 的 图 形 。 在 本 实例 中 ， 将 讲解 这 些 基本 几何 图 形 的 绘制 方法 ， 运 行 结果 如 图 6.36 所 示 。 


图 6.36 绘制 基本 几何 图 形 


图 关键 技术 


在 GD2 函数 库 中 分 别 应 用 imageline0) 函 数 、imagearc0 函 数 和 imagerectangle() 函 数 绘制 直线 、 圆 形 和 方形 。 
imageline0 函 数 用 于 绘制 直线 ， 其 语法 如 下 : 


bool imageline ( resource image, int x1, int y1, int x2, int y2, int color ) 
该 函数 用 颜色 color 在 图 像 image 中 从 坐标 (x1,y1) 到 (x2,y2)( 图 像 左 上 角 坐 标 为 (0, 0)) 绘制 一 条 线段 。 
imagearc0 函 数 用 于 绘制 圆 形 ， 其 语法 如 下 : 


bool imageare ( resource image. int ex. int cy. int w, int h, int s int e, int color ) 


imagearcO 函 数 的 参数 说 明 如 表 6.3 所 示 。 
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表 6.3 imagearc() 函 数 的 参数 说 明 


参 。 数 说 明 

image | 表示 图 像 的 handle 

cx、cy | 原点 坐标 (0.0) 为 图 片 的 左上 角 ， 参 数 cx、cy 为 椭圆 圆心 坐标 
wh | 分 别 为 水 平 轴 长 和 垂直 轴 长 

se | 分 别 为 起 始 角 与 结束 角 

color 弧 线 的 颜色 


imagerectangle() 函 数 用 于 绘制 方形 ， 其 语法 如 下 : 


bool imagerectangle ( resource image, int x1, int yl, int x2, int y2. int col ) 
该 函数 用 颜色 col 在 图 像 image 中 绘制 一 个 方形 ， 其 左上 角 坐 标 为 (x1, y1)， 右 下 角 坐 标 为 (x2, y2)。 图 像 的 
左上 角 坐 标 为 (0, 0)。 


力 设计 过 程 
应 用 GD2 函数 最 基本 的 图 形 绘制 函数 ， 分 别 绘制 直线 、 正 圆 和 正方 形 ， 并 用 白色 作为 线条 基色 ,代码 如 下 ; 
<?php 
ee image/png"); // 将 图 像 输 出 到 浏览 器 
Simg = imagecreate(560, 200); // 创 建 一 个 560X200 的 图 像 
S$bg = imagecolorallocate($img, 0, 0, 255); // 设 置 图 像 背景 色 
S$white = imagecolorallocate(Simg, 255, 255, 255); /设置 绘制 图 像 的 颜色 为 白色 
imageline($img, 20, 20, 150. 180, $white); /| 绘制 一 条 直线 
imagearc($img, 250, 100, 150, 150, 0, 360, Swhite): /绘制 一 个 圆 
imagerectangle($img, 350, 20, 500, 170, $white); /给 制 一 个 正方 形 
imagepng($img); /以 .png 格式 输出 图 形 
imagedestroy($img); /释放 资源 
?> 
秘笈 心 法 


心 法 领悟 304: 在 PHP 中 激活 和 屏蔽 GD2 函数 库 。 

GD 库 是 在 PHP 5.0 中 默认 安装 的 ， 但 是 要 想 激活 GD 库 ， 必 须 修 改 php.ini 文件 。 将 该 文件 中 
的 ;extension=php_gd2.dll 选项 前 的 分 号 “:” 去 掉 ， 保 存 文件 并 重新 启动 Apache 服务 器 即 可 生效 。 如 果 要 屏蔽 对 
GD2 函数 库 的 支持 ， 则 在 extension=php_gd2.dll 选项 前 加 上 分 号 即 可 。 


中 级 | 


起 叶 模 关机 妆容 


实例 305 


力 实例 说 明 


使 用 GD2 函数 不 仅 可 以 绘制 线条 图 形 ， 还 可 以 绘制 填充 图 形 ， 如 填充 圆 形 、 填 充 矩 形 等 ， 在 本 实例 中 ， 将 
介绍 圆 形 和 和 拢 形 的 填充 ， 其 运行 结果 如 图 6.37 所 示 。 


图 6.37 填充 几何 图 形 
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力 关键 技术 
在 GD2 函数 库 中 ， 应 用 imagefill0 函 数 实现 图 像 的 填充 操作 ， 其 语法 如 下 : 


bool imagefill ( resource image, int x, int y, int color) 

该 函数 在 图 像 image 的 坐标 (x,y)〈 图 像 左 上 角 坐 标 为 (0, 0)) 处 用 颜色 color 执行 区 域 填 充 〈 即 与 x，y) 点 颜 
色相 同 且 相 邻 的 点 都 会 被 填充 ) 。 

应 用 imagefilledarc0 函 数 绘 制 一 个 椭圆 弧 线 ， 其 语法 如 下 : 


bool imagefilledarc ( resource image, int cx, int cy, int w, int h int s, int e, int color int style ) 

该 函数 在 image 所 代表 的 图 像 中 以 (cx,cy)〔 图 像 左 上 角 坐 标 为 (0, 0)) 为 坐标 点 绘制 一 椭圆 弧 。 如 果 成 功 返 
回 TRUE, 否则 返回 FALSE。 参数 w 和 h 分 别 指定 椭圆 的 宽 和 高 ; s 和 e 分 别 以 角度 指定 起 始点 和 结束 点 ; style 
可 以 是 下 列 值 按 位 或 (OR) 后 的 值 : 

回 IMG ARC PIE 

回 IMG ARC CHORD 

IMG ARC NOFILL 

回 IMG ARC EDGED 

IMG ARC PIE 和 IMG _ARC _CHORD 是 互 斥 的 。IMG _ARC _CHORD 只 是 用 直线 连接 起 始 和 结束 点 ， 而 
IMG_ARC _PIE 则 产生 圆 形 边界 〈 如 果 两 个 都 用 ，IMG_ARC_CHORD 生效 ) ; IMG_ARC_NOFILL 指明 弧 或 弦 
只 有 轮廓 ， 不 填充 ，IMG_ARC EDGED 指明 用 直线 将 起 始点 和 结束 点 与 中 心 点 相连 ， 和 IMG _ARC _NOFILL 
一 起 使 用 是 绘制 饼 状 图 轮廓 的 好 方法 〈 不 用 填充 ) 。 

应 用 Imagefilledellipse0 函 数 绘制 一 个 椭圆 ， 其 语法 如 下 : 


bool imagefilledellipse ( resource image, int ex, int cy, int w, int h, int color ) 
该 函数 在 image 所 代表 的 图 像 中 以 (cx,cy)( 图 像 左 上 角 坐 标 为 (0, 0)) 为 中 心 绘制 一 个 椭圆 。 参 数 w 和 h 分 
别 指定 椭圆 的 宽 和 高 ，color 指定 填充 颜色 。 如 果 成 功 返回 TRUE， 和 否则 返回 FALSE。 


力 设计 过 程 
本 实例 应 用 GD2 函数 绘制 填充 椭圆 形 和 填充 正方 形 ， 其 代码 如 下 : 
< 


?php 
header("Content-type: image/png"): // 将 图 像 输出 到 浏览 器 
Simg = imagecreate(400, 200); // 创 建 一 个 400X 180 的 图 像 


S$bg = imagecolorallocate($img. 0. 0, 255); 

Swhite = imagecolorallocate($img. 255. 0, 255); 

imagefilledellipse($img, 100, 100. 150, 150. Swhite): /| 绘制 贺 形 
imagefilledrectangle(Simg, 200, S0. 300. 150, $Swhite): /| 绘制 正方 形 
imagepng($img); 

ie 


国 秘笈 心 法 

心 法 领悟 305: 通过 GD2 函数 库 创建 图 像 必 不 可 少 的 函数 。 

在 通过 GD2 函数 库 创建 图 像 时 ，imagedestroy0) 函 数 是 必 不 可 少 的， 可 以 通过 它 销毁 指定 的 图 像 ， 释 放 与 
image 关联 的 内 存 。 如 果 不 应 用 该 函数 ， 与 image 关联 的 数据 将 会 一 直 存 储 在 内 存 中 。 


初级 | 
实例 306 起 味 指数 : 友良 家 
实例 说 明 


在 本 实例 中 ， 介 绍 如 何在 图 像 中 输出 字符 串 〈 注 意 这 里 介绍 的 是 如 何 输出 英文 字符 串 ) ， 其 运行 效果 如 


413 


PHP 开发 实例 大 全 (基础 卷 ) 


6.38 所 示 。 
Do you still love php tomorrow ? 
图 6.38 输出 英文 字符 串 
图 关键 技术 


GD2 函数 库 中 应 用 imagestring0 函 数 在 画布 上 输出 字符 串 ， 其 语法 如 下 : 

bool imagestring ( resource image, int font int x, int y, string s, int col ) 

该 函数 用 颜色 col 将 字符 串 s 绘制 到 image 所 代表 的 图 像 的 (x,y) 处 (这 是 字符 串 的 左上 角 坐 标 ， 整 幅 图 像 的 
左上 角 坐 标 为 (0,0)) 。 如 果 font 是 1、2、3、4 或 5， 则 使 用 内 置 字体 。 
看 设计 过 程 

本 实例 应 用 imagestring0 函 数 在 画布 上 水 平地 绘制 一 行 英文 字符 串 ， 其 代码 如 下 : 

a image/png"); 

S$im = imagecreate(600, 50); 

= (Sim, 255, 255, 255); 


S$bg = imagecolorallocate( 
Sred = imagecolorallocate($im, 255, 0. 0); 
imagestring($im. 5, 0. 0, "Do you still love php tomorrow ?", Sred); // 在 指定 的 坐标 处 ， 水 平 绘制 一 行 红色 的 字符 串 


imagepng($im); /输出 图 像 
imagedestroy(Simg); /销毁 图 像 
> 

图 秘笈 心 ; 


心 法 领悟 306: 输出 中 文字 符 串 。 
在 GD2 函数 库 中 ， 想 要 输出 中 文字 符 串 ， 必 须 将 中 文字 符 串 的 编码 格式 转换 成 UTF-8， 然 后 应 用 
imageTTFTextO 函 数 完成 中 文字 符 串 的 输出 。 如 果 直 接 使 用 imagestring0 函 数 ， 将 输出 乱码 。 


中 级 
趣味 指数 :让 二 广 突 


力 实例 说 明 


PHP 中 的 GD 库 支 持 中 文 ， 但 必须 要 以 UTF-8 格式 的 参数 来 进行 传递 ， 如 果 使 用 imagestringO 函 数 直接 绘 
制 中 文字 符 串 就 会 显示 乱码 。 这 是 因为 GD2 对 中 文 只 能 接收 UTF-8 编码 格式 ， 并 且 默认 使 用 了 英文 的 字体 ， 所 
以 要 输出 中 文字 符 串 必 须 对 其 进行 转 码 ， 并 设置 中 文字 符 使 用 的 字体 ; 否则 ， 输 出 的 只 能 是 乱码 。 在 本 实例 中 ， 
实现 GD2 函数 输出 中 文字 符 串 ， 并 且 通 过 GD2 函数 将 中 文字 符 串 在 照片 上 输出 ， 其 运行 结果 如 图 6.39 所 示 。 


图 6.39 在 照片 上 输出 中 文字 符 串 
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图 关键 技术 
在 PHP 中 ， 在 图 像 中 添加 中 文字 符 串 应 用 的 是 imagettftext 0 函数 ， 其 语法 如 下 : 
array imagettftext ( resource image, float size, float angle, int x, int y, int color string fontfile, string text ) 


imagettftext 0 函数 的 参数 说 明 如 表 6.4 所 示 。 
表 6.4 imagettftext () 函 数 的 参数 说 明 


参数 说 明 

image 图 像 资 源 

size 字体 大 小 。 根 据 GD 版 本 不 同 ， 应 该 以 像素 大 小 (GD1) 或 点 大 小 (GD2)〉 指定 

ii Si 顺 时 针 计 算 ，0” 为 水 平 ， 也 就 是 3 点 钟 的 方向 〈 由 左 到 右 ) ，90” 则 为 由 下 到 上 的 
x 文字 的 义 轴 坐标 值 。 设 定 第 一 个 字符 的 基本 点 

y 文字 的 立轴 坐标 值 。 设 定 字体 基线 的 位 置 ， 不 是 字符 的 最 底 端 

color 文字 的 颜色 

fontfile 字体 的 文件 名 称 ， 也 可 以 是 远 端 的 文件 

text 字符 串 内 容 


在 PHP 中 ， 通 过 GD2 函数 对 JPG 格式 的 照片 进行 操作 应 用 imagecreatefromjpeg0 函 数 ， 根 据 JPEG 文件 或 
URL 新 建 一 个 图 像 ， 其 语法 如 下 : 


resource imagecreatefromjpeg ( string filename ) 
参数 filename 可 以 是 本 地 文件 ， 也 可 以 是 网 络 的 URL 地 址 。 返 回 值 为 JPEG 的 文件 代码 ， 可 供 其 他 函数 使 
用 。 该 函数 在 失败 时 返回 一 个 空 字符 串 ， 并 且 输出 一 条 错误 信息 。 


图 设计 过 程 
本 实例 应 用 imagecreatefromjpeg0 和 imagettftext 0 函数 在 照片 上 添加 中 文字 符 串 ， 其 代码 如 下 : 
<?php 
header("content-type:image/jpeg"); // 定 义 输出 为 图 像 类 型 
S$im=imagecreatefromjpeg("images/P1020494.JPG"):; // 载 入 照片 
S$textcolor=imagecolorallocate($in.25.25.136); // 设 置 字体 颜色 为 蓝 色 ， 值 为 RGB 颜色 值 
S$font="Font/mzd.ttf"; /定义 字体 
S$to=" 落 霞 与 孤 效 齐 飞 "; 
imagettftext($im.80,0,200,200,$textcolor,$font.$to): // 写 TIF 文字 到 图 中 
S$to=" 秋 水 共 长 天 一 色 ": 
imagettftext($im.80.0.300.400.Stextcolor.$font'Sto); // 写 TIF 文字 到 图 中 
imagejpeg($im): // 建 立 JPEG 图 形 
imagedestroy($im); // 结 束 图 形 ， 释 放 内 存 空间 
> 

笈 心 法 


心 法 领悟 307: 必须 牢记 一 点 ，imagettftext0 函 数 只 支持 UTF-8 编码 。 

因为 本 实例 中 页 面 使 用 的 是 UTF-8 编码 格式 ， 所 以 在 定义 向 图 片 中 添加 的 中 文字 符 串 时 可 以 直接 使 用 ， 不 
需要 编码 格式 的 转换 。 但 是 ， 如 果 页 面 本 身 使 用 的 是 GB2312 编码 格式 ， 那 么 就 必须 应 用 iconv0 函 数 对 向 图 片 
中 添加 的 中 文字 符 串 进行 编码 格式 的 转换 ， 由 GB2312 编码 转换 为 UTF-8 编码 。 
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: 
趣味 指数 : 良 育 育 雄 安 ; 


目 


实例 308 


力 实例 说 明 


图 片 是 Web 页 面 最 为 重要 的 组 成 元 素 之 一 ， 新 闻 网 站 、 图 片 资 料 网 站 等 备 受 网 民 关注 的 网 站 每 天 都 会 上 传 
大 量 的 图 片 。 如 果 直 接 将 图 片上 传 到 页 面 中 ， 很 可 能 被 浏览 者 保存 使 用 ， 这 样 站 点 的 版 权 就 不 能 很 好 地 得 到 保 
证 。 如 果 在 上 传 图 片 过 程 中 ， 动 态 地 为 图 片 添加 水 印 效果 ， 这 样 不 仅 可 以 对 保证 站 点 版 权 起 到 一 定 作用 ， 如 果 
设计 合理 还 能 有 助 于 网 站 的 推广 。 在 本 实例 中 ， 将 讲解 如 何在 上 传 图 片 的 过 程 中 为 图 片 添加 水 印 文字 ， 其 运行 
结果 如 图 6.40 所 示 。 
六 商品 详 位 


$s FHP 开发 开 于 恒 志 大 全 
图 本 -程序 开发 


图 6.40 为 上 传 图 片 添加 文字 水 印 


力 关键 技术 


为 上 传 图 片 添加 水 印 的 重点 是 图 像 处 理 函 数 的 运用 ， 至 于 文件 的 上 传 已 经 在 前 面 的 实例 中 进行 了 详细 的 讲 
解 ， 这 里 不 再 乾 述 。 本 实例 运用 的 关键 技术 如 下 : 

(1) 创建 图 像 函 数 

创建 图 像 函 数 的 运用 是 完成 本 实例 的 第 一 步 ， 因 为 需要 根据 上 传 图 片 的 后 级 (格式 ) 运用 不 同 的 函数 来 创 
建新 图 像 ， 这 里 定义 3 种 格式 (GIF、JPG 和 PNG) 的 图 片 ， 所 以 要 应 用 到 3 个 创建 图 像 函数 ， 分 别 是 : 

加 ”imagecreatefromgif() 函 数 : 根据 GIF 文件 或 者 URL 新 建 一 个 图 像 ， 返 回 图 像 标识 符 。 

回 imagecreatefromjpeg() 函 数 : 根据 PG 文件 或 者 URL 新 建 一 个 图 像 ， 返 回 图 像 标识 符 。 

加 ”imagecreatefrompng0 函 数 : 根据 PNG 文件 或 者 URL 新 建 一 个 图 像 ， 返 回 图 像 标识 符 。 

(2) 操作 图 像 函 数 

新 图 像 创 建成 功 后 将 返回 一 个 图 像 标 识 符 ,操作 图 像 函 数 根据 标识 符 对 图 像 进行 操作 ， 这 里 应 用 两 个 函数 : 

加 ”imagecolorallocate() 函 数 : 定义 水 印 文字 的 颜色 。 

加 ”imagettftext() 函 数 ， 在 返回 的 图 像 中 输入 中 文字 符 串 。 

(3) 输出 图 像 函数 

与 创建 图 像 函数 对 应 ， 同 样 有 3 个 输出 图 像 函 数 : 

加 ”imagegif0 函 数 :以 GIF 格式 将 图 像 输出 到 浏览 器 或 文件 。 

加 ”imagejpeg0 函 数 : 以 JPG 格式 将 图 像 输出 到 浏览 器 或 文件 。 

imagepng0 函 数 : 以 PNG 格式 将 图 像 输出 到 浏览 器 或 文件 。 

(4) 销毁 图 像 函 数 

在 完成 图 像 的 创建 和 输出 之 后 ， 有 必要 销毁 图 像 ， 释 放 与 image 相关 的 内 存 ， 其 应 用 的 是 imagedestroy0 函 
数 ， 语 法 如 下 : 

bool imagedestroy (resouree image ) 

该 函数 释放 与 image 关联 的 内 存 。 参 数 image 是 由 图 像 创 建 函 数 返回 的 图 像 标 识 符 。 

在 本 实例 中 ， 要 对 上 述 函 数 进行 整合 应 用 ,创建 AddWaterPress 类 ， 定 义 getExtendsName() 方 法 ， 获 取 上 传 
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图 片 的 文件 后 级 ;定义 getImageRes0 方 法 ， 根 据 上 传 文件 的 后 缀 创建 新 图 像 ， 定 义 outputImage0 方 法 ， 输 出 图 
像 ， 定义 add0 方 法 ， 向 指定 的 图 片 中 添加 文字 水 印 。 


图 设计 过 程 

(1) 创建 index.php 文件 。 首 先 创 建 一 个 表单 ， 完 成 上 传 图 片 的 提交 操作 。 然 后 在 本 页 中 输出 存储 在 服务 
器 指定 文件 夹 下 的 图 片 。 最 后 获取 表单 中 提交 的 图 片 数 据 , 应 用 move_uploaded_file() 函 数 完成 图 片 的 上 传 操作 ， 
并 且 实 例 化 存储 在 AddWaterPress.php 文件 中 的 AddWaterPress 类 ， 调 用 add() 方 法 为 指定 的 图 片 添加 文字 水 印 ， 
其 关键 代码 如 下 : 


这 move uploaded_file($_FILES["file"]["tmp_name"]. $saveDir){ // 执 行文 件 上 传 操作 

require_once 'AddWaterPress.php'; // 包 含 添加 水 印 操作 的 文件 
SaddWaterPress = new AddWaterPress(); // 类 的 实例 化 
SaddWaterPress->add($saveDir, "吉林 省 明日 科技 "); // 执 行 添加 方法 ， 传 递 参 数 ， 指 定 水 印 文字 


echo "<script>alert( 图 片 添加 成 功 "):</script>"; 


0 创建 AddWaterPress.php 文件 ， 编 写 AddWaterPress 类 的 内 容 ， 其 关键 代码 如 下 : 


区 AddWaterPress{ // 定 义 类 文件 
/省 略 了 部 分 代码 
function add($imageUrl, SwatherImageUrD{ // 定 义 添加 方法 
Simg = @$this->getImageRes($this->getExtendsName($imageUrl), SimageUrl); ”// 获 取 被 操作 的 图 像 标识 
Stextcolor=imagecolorallocate($img,190,1,23); // 设 置 字体 颜色 为 蓝 色 ， 值 为 RGB 颜色 值 
Stont="FonWFZHCJW.TIF"; // 定 义 字 体 
imagettftext($img,15,56.,20,130,$textcolor, $font, S$watherImageUr]); // 写 TIF 文字 到 图 中 


// 根 据 图 像 标识 符 、 后 级 和 路 径 ， 执 行 outputtmage(0 方 法 ， 输 出 图 像 

Sthis->outputImage(Simg, $this->getExtendsName(SimageUrl), SimageUrl): 

imagedestroy($img); /销毁 图 像 
} 


国 秘笈 心 法 
心 法 领悟 308， 添加 英文 字符 串 作 为 水 印 标记 。 


本 实例 中 完成 的 是 中 文字 符 串 水 印 标记 的 添加 操作 ， 如 果 要 添加 英文 字符 串 格式 的 水 印 标记 ， 可 以 直接 使 
用 imagestring(O) 函 数 来 完成 ， 其 方法 与 在 图 像 中 输出 英文 字符 串 是 相同 的 。 


实例 309 


四 实例 说 明 


实例 308 介绍 的 是 如 何 为 照片 添加 文字 水 印 , 在 本 实例 中 将 介绍 如 何 为 
上 传 图 片 添加 一 个 图 像 水 印 ， 其 运行 结果 如 图 6.41 所 示 。 


图 关键 技术 


使 用 图 片 作为 水 印 的 前 提 是 这 个 图 片 的 背景 必须 是 透明 的 , 否则 输出 的 。 图 6.41 为 图 片 添加 图 像 水 印 
效果 很 不 理想 。 添加 图 片 水 印 的 关键 是 getimagesize0 和 imagecopy0 函 数 。 应 用 getimagesize0 函 数 获取 上 传 图 片 
和 水 印 图 片 的 大 小 ， 通 过 imagecopy0 函 数 完成 图 片 水 印 的 添加 。 

imagecopy0 函 数 ， 将 图 像 复制 到 指定 的 另外 一 个 图 像 中 ， 其 语法 如 下 : 


bool imagecopy ( resource dst_ im resouree sre_im, int dst_x, int dst_y, int sre_x, int sre_y, int sre_w, int sre_h ) 
将 图 像 src_im 中 坐标 从 (sre_x,sre_y) 开 始 ， 宽 度 为 sre_w， 高 度 为 src_h 的 一 部 分 复制 到 图 像 dst_im 中 坐标 
为 (dst_x,dst_y) 的 位 置 上 。 
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在 本 实例 中 , 同样 是 整合 图 像 的 创建 、 操 作 、 输 出 和 销毁 函数 , 创建 AddWaterPress 类 , 定义 getExtendsName() 
方法 , 获取 上 传 图 片 的 文件 后 组 ; 定义 getImageRes0 方 法 , 根据 上 传 文件 的 后 缀 创建 新 图 像 ; 定义 outputImage0 
方法 ， 输 出 图 像 ， 定 义 add0 方 法 ， 向 指定 的 图 片 中 添加 图 像 水 印 。 


图 设计 过 程 
本 实例 的 实现 步骤 与 实例 308 相同 ， 唯 一 的 区 别 是 创建 AddWaterPress.php 文件 ， 编 写 AddWaterPress 类 的 
add() 方 法 时 ， 应 用 的 是 getimagesize0 和 imagecopy0O 函 数 完成 图 像 水 印 的 添加 操作 。add(0 方 法 的 代码 如 下 : 


function add($imageUrl, $watherImageUrl, $x, $y){ // 定 义 添加 方法 
Simg = @$this->getImageRes($this->getExtendsName($imageUrl), $imageUrl); ”// 获 取 被 添加 的 图 像 标识 
Simgl = @$this->getImageRes($this->getExtendsName($watherImageUr]), $watherImageUr]); 


S$size = getimagesize($imageUrl); // 获 取 图 像 大 小 
$sizel = getimagesize($watherImageUrl); /获取 水 印 图 片 的 大 小 
if($x—null && $y—null){ /判断 参数 是 否 为 空 
$x1 = ($size[0]-Ssize1[0])/2; // 根 据 图 像 大 小 数组 中 返回 的 值 ， 计 算 图 像 的 横 坐 标 
$yl = ($size[1]-$sizel[1D/2; // 根 据 图 像 大 小 数组 中 返回 的 值 ， 计 算 图 像 的 纵 坐 标 
Jelse{ 
$xl = $x; // 如 果 不 为 空 ， 则 直接 使 用 坐标 数据 
Syl = $y; // 如 果 不 为 空 ， 则 直接 使 用 坐标 数据 
imagecopy($img, $img1, $x1, $y1, 0. 0. $sizel[0], Ssize1[1]); // 将 imgl 的 一 部 分 复制 到 img 的 指定 位 置 
S$this->outputImage($img, $this->getExtendsName($imageUrl), $imageUr]); /根据 图 像 标 识 符 、 后 缀 和 路 径 ， 执 行 outputImage() 方 法 ， 
imagedestroy($img1); /销毁 图 像 
imagedestroy($img); /销毁 图 像 
} 
力 秘笈 心 法 


心 法 领悟 309: 使 用 背景 透明 的 图 片 作为 水 印 图 片 效果 更 好 。 
在 将 图 片 作 为 水 印 图 像 时 ， 如 果 指 定 的 图 片 背景 不 是 透明 的 ， 那 么 添加 的 水 印 图 像 将 与 原始 图 像 格格 不 入 ， 
而 如 果 水 印 图 片 的 背景 是 透明 的 ， 那 么 添加 的 水 印 标记 就 可 以 很 好 地 与 原始 图 像 融 入 一 体 。 


Eee 一 
起 呆 指 孝 ， 南 太 页 从 
图 实例 说 明 


验证 码 技术 的 应 用 是 为 了 提高 站 点 的 安全 性 ， 避 免 因 网 页 运行 速度 慢 而 造成 数据 的 重复 提交 。 本 实例 中 ， 
将 通过 JavaScript 脚本 和 GD2 函数 开发 一 个 无 刷新 验证 码 ， 其 运行 结果 如 图 6.42 所 示 。 


符 作 . 有 请 的 个 be - 


py 用 用 


| 一 ss 3 
图 6.42 GD2 函数 生成 图 形 验证 码 
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图 关键 技术 


应 用 JavaScript 脚本 和 GD2 函数 开发 一 个 无 刷新 验证 码 ， 涉 及 的 技术 包括 随机 数 的 生成 、 随 机 数 如 何 传递 
给 图 像 生成 页 、 数 字 图 像 的 生成 以 及 验证 码 的 二 次 生成 。 这 里 重点 介绍 验证 码 图 像 的 生成 。 

(1) 创建 ValidatorCode.php 页 面 ， 应 用 GD2 函数 库 中 的 函数 ， 根 据 超 链接 传递 的 参数 值 生 成 验证 码 图 像 。 
主要 应 用 的 函数 如 下 : 
imagecreate() 函 数 : 创建 验证 码 图 像 的 画布 。 
imagecolorallocate0 函 数 : 定义 画布 的 填充 颜色 。 
imagefill() 函 数 :根据 imagecolorallocateO) 函 数 定义 的 颜色 ， 完 成 图 像 颜 色 的 填充 操作 。 
imagestring() 函 数 : 将 从 超 链 接 中 获取 的 验证 码 值 写 入 图 像 中 ， 并 且 应 用 imagecolorallocate0 函 数 随机 
定义 值 输 出 的 颜色 。 

回 imagepngO 函 数 : 生成 PNG 格式 的 图 像 。 

加 ”imagedestroy0 函 数 : 销毁 图 像 ， 释 放 内 存 。 

(2) 验证 码 的 二 次 生成 。 其 实现 原理 类 似 于 do...while 循环 语句 ， 无 论 条 件 是 否 满足 ， 默 认 都 会 执行 一 次 
(打开 网 页 后 ， 直 接生 成 一 个 验证 码 ) 。 然 而 要 想 使 其 继续 执行 ， 就 必须 满足 指定 的 条 件 〈 重 新 生成 验证 码 ， 
就 必须 调用 指定 的 方法 ) 。 依 据 这 个 原理 ， 在 JavaScript 脚本 中 定义 如 下 方法 : 


加 加 加 加 


function reCodeO{ // 定 义 方法 ， 重 新 生成 验证 码 
var num1=Math.round(Math.random()*10000000); // 生 成 随机 数 

var num=numl :toString().substr(0,4); // 截 取 随 机 数 
document.codeimg.sre="ValidatorCode.php?code="+num: // 将 截取 值 传递 到 图 像 处 理 页 中 
forml.defValidatorCode.value=num:; // 将 截取 值 赋 给 表单 中 的 隐藏 域 


在 上 述 方法 中 ， 重 复 执行 JavaScript 脚本 中 默认 的 操作 ， 即 重新 生成 一 个 验证 码 。 
图 设计 过 程 
(1) 创建 index.php 页 面 ， 定 义 form 表单 ， 设 计 用 户 注册 页 面 的 效果 。 
(2) 编写 JavaScript 脚本 ， 生 成 验证 码 ， 并 定义 reCode0 方 法 ， 用 于 验证 码 的 二 次 生成 ， 其 关键 代码 如 下 : 


<script language="javascript"> 
var numl=Math.round(Math.random()*10000000); // 生 成 随机 数 


var num=numl .toString().substr(0,4); // 截 取 随 机 数 的 前 4 个 字符 
document write("<img name=codeimg sre=ValidatorCode php?code="+numt ">"): // 将 值 传递 到 图 像 页 

forml .defValidatorCode.value=num; // 将 截取 值 赋 给 表单 中 的 隐藏 域 
</script> 


(3) 创建 超 链接 ， 调 用 JavaScript 脚本 中 的 reCode() 方 法 ， 实 现 验证 码 的 二 次 生成 ， 其 代码 如 下 : 


<a href="javascript:reCode()" class="al"> 看 不 清 </a> 


(4) 创建 ValidatorCode.php 页 面 ， 根 据 超 链接 中 传递 的 随机 数 ， 应 用 GD2 函数 生成 验证 码 的 数字 图 像 ， 


其 关键 代码 如 下 : 
<?php 
header('content-type:image/png'); /定义 标题 .png 格式 图 像 
Sim = imagecreate(65. 25); // 定 义 画布 
imagefill($im. 0, 0, imagecolorallocate(Sim. 200, 200, 200)): /区域 填充 
SvalidatorCode = $_GET['code']: // 获 取 提 交 的 值 


imagestring(Sim. rand(3. 5). 10, 3, substr($validatorCode. 0, 1). imagecolorallocate($im. 0. rand(0. 255). rand(0. 255))): 
imagestring($im. rand(3. 5). 25, 6. substr($validatorCode. 1. 1), imagecolorallocate($im. rand(0. 255). 0. rand(0. 255))): 
imagestring($im., rand(3. 5). 36. 9, substr($validatorCode. 2, 1). imagecolorallocate($im. rand(0. 255). rand(0. 255). 0)): 
imagestring(Sim, rand(3, 5), 48, 12. substr($validatorCode. 3. 1), imagecolorallocate(Sim. 0. rand(0. 255), rand(0. 255))): 
imagepng($im): // 生 成 PNG 图 像 
imagedestroy(); /销毁 图 像 


(5) 在 js 文件 夹 下 ， 创 建 一 个 js 脚本 文件 ， 定 义 chkinput0 方 法 ， 对 表单 中 提交 的 注册 信息 进行 验证 ， 包 
括 验 证 码 是 否 正确 。 其 完整 代码 请 参考 本 书 光盘 。 
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心 法 领悟 310: 生成 带 有 干扰 线 的 数字 图 形 验 证 码 。 
在 本 实例 中 ， 应 用 GD2 函数 生成 的 是 清晰 的 数字 图 形 验证 码 ， 图 6.43 ”增加 干扰 背景 后 的 验证 码 图 像 
还 可 以 在 此 基础 上 为 验证 码 增加 干扰 背景 ， 使 其 看 上 去 模糊 一 些 ， 如 
图 6.43 所 示 。 
其 具体 方法 如 下 : 在 ValidatorCode .php 文件 中 ， 通 过 for 循环 语句 ， 应 用 imagesetpixel0 函 数 在 画布 的 背景 


上 绘制 一 些 单一 元 素 ， 代 码 如 下 : 
for ($i= 0; $i< 200; $i++) { // 填 充 干扰 背景 
imagesetpixel($im, rand() % 70, randO % 30, imagecolorallocate($im, rand(0, 255), rand(0, 255), rand(0, 255))); 


高 级 | 


实例 311 趣味 指数 : odobolodad 


力 实例 说 明 
在 本 实例 中 ， 运 用 GD2 函数 自行 编写 一 个 绘制 折线 图 的 方法 ， 对 2009 年 公司 网 站 的 月 访问 量 进行 分 析 。 
本 实例 中 的 方法 完全 由 笔者 自行 编写 ， 不 借助 于 任何 图 像 的 操作 类 库 ， 其 运行 结果 如 图 6.44 所 示 。 


Y 
100% 


和 


ee | 一 -| 
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19.59X 0.78X 6.58X 1.17X 3.94X 2.27% 4.62X 9.5% 0.59X 4.91X 43.39X 2.47X 


6.44 ”GD2 折线 图 分 析 网 站 月 访问 量 走势 


图 关键 技术 


本 实例 中 ， 通 过 GD2 函数 绘制 网 站 访问 量 走势 分 析 图 ， 其 中 涉及 的 关键 技术 如 下 : 
(1) 应 用 imageline0 函 数 绘制 线条 。 
imageline0 函 数 用 指定 颜色 在 图 像 中 两 点 之 间 绘 制 一 条 线段 ， 语 法 如 下 : 


bool imageline ( resource image, int xl, int yl, int x2, int y2, int color ) 

参数 说 明 : 

image: 图 像 标识 。 

x1: 起 始点 的 横 坐 标 。 

y1: 起 始点 的 纵 坐 标 。 

x2: 结束 点 的 横 坐 标 。 

y2: 结束 点 的 纵 坐标 。 

color: 颜色 标识 。 

(2) 应 用 百分比 来 显示 数据 信息 ， 并 通过 round0 函 数 将 数字 小 数位 进行 四 舍 五 入 操作 ，round0 函 数 的 语 
法 如 下 : 


double round(double val) 
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val: 进行 四 合 五 入 操作 的 小 数 。 


力 设计 过 程 


(1) 编写 index.php 文件 ， 创 建 表单 ， 添 加 12 个 表单 元 素 ， 提 交 网 站 的 月 访问 量 数 据 。 
(2) 创建 img.php 文件 ， 获 取 表单 中 提交 的 网 站 月 访问 量 数 据 ， 并 对 数据 统计 分 析 。 通 过 GD2 函数 创建 


一 个 折线 图 输出 统计 分 析 的 结果 ， 其 关键 代码 如 下 : 
<?php 


Sdata = array ($_ POST ["T1"], $_POST ["T2"], $_POST ["T3"],$_ POST ["T4"], $_ POST ["Ts"].$_ POST ["T6"].$_POST ["T7"].$_POST ["Ts"]， 


$ POST ["T9"], $_POST ["T10"], $_POST ["T11"], $_POST ["T12"] ); 


Smonth = array ("Jan", "Feb", "March", "April”, "May", "June", "July", "Aug", "Sep". "Oct", "Nov", "Dec" ); 


Smax = 0; 
for($i=0; $1< 12; $i++) { 

Smax = Smax + $data [$i]: 
} 


Sim = imagecreate ( 550, 300 ); 

Sgreen = imagecolorallocate ( $im, 214, 235, 214 ); 
Sblack = imagecolorallocate ( $im, 0, 0, 0 ); 

S$red = imagecolorallocate ( $im, 255. 0. 0 ); 

Sblue = imagecolorallocate ( $im, 0, 0, 255 ); 
imageline ( $im, 30, 230, 520, 230, $blue ); 
imageline ( $im, 30, 5, 30, 230, $blue ); 
imagestring ( $im, 3, 520, 222, "X", $black ); 
imagestring ( $im, 3, 16, 1, "Y", $black ); 

$1= 190; 

Sk1 


for($j = 0; $j < 12; $j ++) { 
imageline ( $im, $k1, $1, $k2, $1, $black ); 
$1= $1- 40; 


for($j =0; $j < 12; $) ++) { 
imageline ( $im, $f, $z1, $f, $z2, $black ): 
Sf= $f+ 40; 


} 

S$1= 185; 

for($j =1; $j< 6; $j ++) { 
imagestring ( Sim, 2, 2, $1, 20 * $j . "%", Sred ); 
$1= $1- 40; 

} 

$x=20; 

$y =230; 

for($i= 1: $i< 12; $i++) { 
Sy lt=$y- ((Sdata [$i- 1] / Smax) * 200): 
$y_ht = $y - ($data [$i] / $max) * 200): 


imageline ( Sim, $x * ($i* 2- 1) +30, $y_lt, $x * ($i+ 1) * 2- 1) +30, $y_ht, Sred ); 


} 

for($i=1: $i< 13: $i++) { 
$rl =round ( (($data [$i- 1]) / Smax) * 100, 2 ): 
imagestring ( $im, 2, $x * (Si - 1) * 2+ 40, $y + 11. Smonth [$i- 1], $black ): 
imagestring ( $im, 2, $x + ($i- 1) + 2 + 36, $y + 25, Srl . "9%", Sred ): 

} 

imagepng ( $im ): 

imagedestroy ( $im ): 


国 秘笈 心 法 
心 法 领悟 311: 折线 图 中 数据 的 获取 方式 。 


1/ 所 有 网 站 访问 量 的 累加 和 


// 创 建 画 布 
/设置 颜色 值 


/设置 入 轴 横 坐 标 
/设置 Y 轴 纵 坐标 
/输出 字符 X 
/输出 字符 站 


/设置 入 轴 网 格 线 横 坐 标 


// 设 置 Y 轴 网 格 线 纵 坐 标 


// 设 置 网 站 访问 量 的 纵 坐 标 值 
// 获 取 每 月 网 站 访问 量 数 的 纵 坐 标 值 
// 维 制 网 站 访问 量 折线 图 


/| 输出 月 份 的 值 
/输出 网 站 访问 量 的 百分比 


/释放 图 像 资 源 


在 本 实例 中 ， 将 表单 提交 的 数据 直接 作为 折线 图 分 析 的 数据 。 另 外 ， 还 可 以 将 数据 库 中 读 取 的 数据 作为 折 
线 图 分 析 的 数据 ， 其 实现 方法 与 将 数据 库 中 的 数据 输出 到 页 面 中 是 相同 的 。 
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实例 312 


力 实例 说 明 


在 网 站 中 ， 经常 需要 对 相关 的 信息 进行 调查 统计 ， 然 后 根据 访 
问 者 的 投票 结果 制订 相关 计划 , 为 了 能 够 更 直观 地 查看 访问 者 的 投 
票 结果 ， 本 实例 采用 柱 形 图 显示 编程 词典 满意 度 的 投票 结果 ， 其 运 
行 结果 如 图 6.45 所 示 。 


力 关键 技术 


通过 GD2 函数 创建 柱 形 图 ， 关 键 是 应 用 imagefilledrectangle0 图 645 GD2 函数 柱 形 图 分 析 编程 词典 
函数 完成 柱 形 图 的 绘制 及 填充 ， 其 语法 如 下 : 清 意 度 调查 

bool imagefilledrectangle ( resource image, int xl, inty1, int x2, int y2, int color ) 

参数 说 明 : 

image: 图 像 资源 。 

x1: 柱 形 图 左上 和 角 横 坐标 。 

y1: 柱 形 图 左上 角 纵 坐 标 。 

x2: 柱 形 图 右 下 角 横 坐标 。 

y2: 柱 形 图 右 下 角 纵 坐标 。 

color: 填充 颜色 。 

在 本 实例 中 ,将 从 数据 库 中 读 取 的 数据 以 柱 形 图 的 形式 进行 展示 ， 实 现 柱 形 图 与 数据 库 中 数据 的 完美 结合 。 
图 设计 过 程 

(1) 创建 index.php 页 面 ， 编 写 <img> 标 签 输出 img.png 图 像 ， 即 输出 柱 形 图 统计 结果 。 

(2) 创建 mg.php 文件 ， 从 数据 库 中 读 取 数据 ， 将 从 数据 库 中 读 取 的 数据 以 柱 形 图 形式 进行 输出 ， 其 关键 
代码 如 下 : 

CE "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 

include ("conn/conn.php");: 


$query = mysql_query ( "select sum(ticket) as total from tb_comment" ); 
Sinfo = mysql_fetch_array ( $query ); 


Smax = $info [total]: /所 有 投票 的 累加 和 
$sql = mysql_query ( "select * from tb_comment" ); 

Sresult = mysql_fetch_array ( $sql ); // 检 索 数 据 信息 
S$im = imagecreate ( 350. 300 ): // 创 建 画 布 
S$green = imagecolorallocate ( $im., 233, 240, 151 ): /设置 颜色 值 


Sblack = imagecolorallocate ( $im. 0. 0. 0 ): 
Sred = imagecolorallocate ( $im, 255. 0.0 ): 
Sblue = imagecolorallocate ( $im. 0. 0, 255 ); 


imageline ( $im. 30. 230. 290. 230. $blue ): // 设 置 X 轴 横 坐 标 
imageline ( $im, 30, 5, 30. 230, $blue ); /设置 站 轴 纵 坐 标 
imagestring ( $im, 3, 295. 222, "X", $black ); /输出 字符 和 
imagestring ( $im. 3, 16. 1. "Y". $black ): /输出 字符 

$1= 190: 

Sk1 =30; 

S$k2 =280; 

for($j =0; $j < 5; Sj ++) { 

imageline ( $im, $k1, $l, $k2, $1, $black ); /设置 入 轴 网 格 线 横 坐 标 


$1=$1- 40; 
} 
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Sf= 80; 

S$z1 = 20; 

$22 = 228; 

for($j=0; $j <4: j++) { 

imageline ( $im, $f $21, $f, $22, $black ): /设置 立轴 网 格 线 纵 坐标 
Sf= $f+ 50; 


} 
$1= 185; 
for($j =1; $<6;5++) { 
imagestring ( $im, 2, 2, $1, 20 * $j . "%", Sred ); 
$1=$1- 40; 
} 
Sx=45; 
$y = 230; 
Sx_width = 20; 
S$y_ht=0; 
do{ 
这 ($result [comment] 一 "好 ") { 
Scomment = "好 "; // 定 义 输出 字体 串 


} 
六 ($result [comment] 一 "良好 ") { 
Scomment = "良好 " 


} 
于 ($result [comment] 一 "一般") { 
Scomment =" 


} 
让 (Sresult [comment] 一 " 差 ") { 
Scomment ; 


二" 差 "; // 定 义 输出 字体 串 

} 

Sfnt = "FontFZHCJW.TTF"; // 定 义 字体 

$y_ht = round ( ($result [ticket] / $max) * 200, 2 ); /设置 投票 结果 所 占 百分比 

S$y_ht] = round ( ($result [ticket] / $max) * 100. 2 ); /设置 投票 结果 所 占 百分比 
imagefilledrectangle ( $im, $x, $y, $x + $x_width, $y - $y_ht, Sred ): // 欠 制 并 填充 柱 形 图 

imagestring ( $im, 2, $x + $x_width - 20, $y - $y_ht - 20, $y_ht] . "%", Sblack ); /设置 投票 结果 所 占 百分比 
imageTTFText ( $im, 15, 0, $x +2, $y + 20, $black, $fnt, $comment ); // 写 TIF 文字 到 图 中 

$x += ($x_width + 30); /设置 两 柱 形 图 之 间 的 宽度 为 30 像素 


} while ( $result = mysql_fetch_array ( $sql ) ); 
Stext="『 编程 词典 满意 度 调查 」 投 票 结果 "; 


imageTTFText ( $im., 15, 0. 10, $y + 50, $black, $fnt, $text ); // 写 TTF 文字 到 图 中 
imagedestroy ( $im ); /释放 图 像 资源 
?> 
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心 法 领悟 312: 注意 编码 格式 的 选择 。 

在 本 实例 中 运用 的 是 UTF-8 编码 格式 , 所 以 在 图 像 中 输出 中 文字 符 串 时 可 以 直接 应 用 imageTTFText0 函 数 ; 
如 果 页 面 使 用 的 是 GB2312 编码 格式 , 那么 要 输出 中 文字 符 串 时 , 就 必须 将 中 文字 符 串 转换 成 UTF-8 编码 格式 ， 
否则 将 输出 乱码 。 


析 图 书市 场 的 份额 高 级 


趣味 指数 : 寅 视 禄 禄 家 


| 
| 
: 
| 


力 实例 说 明 


在 调查 某 类 商品 的 市 场 占有 率 时 ， 最 好 的 显示 方式 就 是 使 用 饼 形 图 ， 通 过 饼 形 图 可 以 直观 地 看 到 某 类 产品 
的 不 同 品牌 在 市 场 中 的 占有 比例 。 运 行 本 实例 ， 通 过 饼 形 图 将 不 同 语言 的 软件 图 书 在 市 场 中 的 占有 率 显 示 出 来 ， 
运行 结果 如 图 6.46 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 
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图 6.46 饼 形 图 分 析 软 件 图 书市 场 占有 率 


图 关键 技术 


(1) 绘制 椭圆 弧 线 使 用 GD2 函数 库 中 的 imagefilledarc0 函 数 , 该 函数 在 指定 图 像 标识 所 代表 的 图 像 中 以 图 
像 左 上 角 为 坐标 点 绘制 一 个 椭圆 弧 。 如 果 成 功 返 回 TRUE， 否 则 返回 FALSE， 函 数 的 语法 如 下 : 


bool imagefilledare ( resource image, int cx, int cy, int w, int h, int s, int e, int color, int style ) 

参数 说 明 : 

image: 图 像 标识 。 

cx: 图 像 左 上 角 的 横 坐 标 。 

cy: 图 像 左 上 角 的 纵 坐 标 。 

w: 椭圆 的 宽度 。 

h: 椭圆 的 高 度 。 

s: 以 角度 指定 椭圆 的 起 始点 。 

e: 以 角度 指定 椭圆 的 结束 点 。 

color: 颜色 标识 。 

style: 可 以 是 IMG_ARC_PIE、IMG_ARC_CHORD、IMG_ARC NOFILL、IMG_ARC_EDGED 按 位 或 (OR) 
后 的 值 IMG_ARC _PIE 和 IMG ARC_CHORD 是 互 斥 的 , IMG _ ARC _CHORD 只 是 用 直线 连接 了 起 始点 和 结束 
点 ，IMG_ARC _PIE 则 产生 圆 形 边界 (如 果 两 个 都 用 ，IMG_ARC_CHORD 生效 ) ; IMG_ARC_NOFILL 指明 弧 
或 弦 只 有 轮廓 , 不 填充 ; IMG_ARC_EDGED 指明 用 直线 将 起 始点 和 结束 点 与 中 心 点 相连 , 和 IMG _ARC NOFILL 
一 起 使 用 是 绘制 饼 状 图 轮廓 的 好 方法 《而 不 用 填充 ) 。 

(2) 应 用 绘制 柱 形 图 的 方法 ， 通 过 柱 形 图 展示 不 同 颜色 代表 的 数据 。 有 关 柱 形 图 的 应 用 请 参考 实例 312。 

(3) 充分 展示 数据 库 中 数据 与 图 形 结合 的 方法 。 分 别 运 用 for 语句 和 while 语句 对 数据 库 中 的 数据 进行 循 
环 输出 。 
图 设计 过 程 

(1) 创建 index.php 文件 ， 连 接 数 据 库 ， 执 行 查询 语句 ， 获 取 数 据 库 中 总 的 图 书 销量 值 ， 并 通过 <img> 标 签 
调用 图 像 处 理 文件 caky_img.php。 

(2) 创建 caky_img.php 文件 ， 通 过 饼 形 图 和 柱 形 图 联合 分 析 各 语言 图 书 的 市 场 份额 。 首 先 获取 表单 中 传 


递 的 总 的 图 书 销量 值 ， 并 计算 各 部 门 图 书 销量 值 占 总 图 书 销量 的 比例 ， 然 后 根据 比例 值 创建 饼 形 图 ， 最 后 通过 
柱 形 图 输出 不 同 的 颜色 区 块 代表 的 图 书 ， 其 关键 代码 如 下 : 


<?php 


include ("conn/conn.php"): /连接 数据 库 
$query = mysql_query ( "select product_count from tb_data " ): // 执 行 查询 语句 
S$data = array (): // 定 义 空 数组 
while ( $myrow = mysql fetch array ($query ) ) { 
$data [] = Smyrow [product_count]: // 将 查询 结果 写 入 数组 中 
// 定 义 图 像 宽度 
// 定 义 图 像 高 度 
// 定 义 饼 形 图 宽度 
// 定 义 饼 形 图 高 度 
/1/ 角 度 
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for($i= 0; $i< count ( $data ); $i++) { 

f(! is_numeric ( $data [$i] )) // 判 断 数 组 中 的 值 是 否 为 空 

die ("1"): 

Stotal += $data [$i]: 
} 
for($i= 0; $i< count ( $data ); $i++) { 

array_push ( $angle, round ( 360 * $data [$i] / $total ) ); // 定 义 饼 形 图 的 角度 值 
} 
Simage = imagecreate ( $widths, $heights ); // 创 建 饼 形 图 的 画布 
Swhite = imagecolorallocate ( $image, OxEE, OxEE, OxEE ); /定义 背景 颜色 
S$color = array (array (imagecolorallocate ( $image, 0x97, Oxbd, 0x00) ); // 定 义 图 像 的 颜色 值 
Srounds x = $width /2; // 原 线 
for(Sh = $height /2+ 5; $h > $height /2- 5; $h --) { 


$start = 0; 
Sstop = 0; 
for($i= 0; $i < count ( $data ); $1 ++) { 

$start = $start + 0; 

Sstop = $start + $angle [$1]: 

Scolor i= fmod ( $i, 10 ); 

imagefilledarc ( $image, Srounds_x, $h, $width, $height - 20, $start, $stop, $color [1] [$color ij, IMG_ARC _PIE ); /创建 饼 形 图 

Sstart += $angle [$1]; 

Sstop += $angle [$i]:; 


} 


} 
for($1= 0; $i < count ( $data ); $i ++) { 
Sstart = $start + 0; 
$stop = $start + $angle [$i]; 
$color i= fmod ( $i, 10 ); 
imagefilledarc ( $image, $rounds_x, $h, $width, Sheight - 20, $start, $stop, $color [0] [$color i], IMG_ARC_PIE ); 


$start += $angle [$i]: 
$stop += $angle [Sil; 

} 

S$fnt = "FontFZHCJW.TTF"; // 定 义 字体 

Sm=-1; 

Sresult = mysql_query ( "select * from tb_data " ); // 读 取 数 据 库 中 存储 的 数据 

while ( $myrow = mysql_feteh_array ( $result ) ) { /hwhile 循环 输出 数据 库 中 的 数据 
$m++; 


imagefilledrectangle ( $image, 295, 15 + 20 * $m, 380, 5 + 20 * Sm, $color [0] [$m] ); 。 // 绘 制 并 填充 柱 形 图 

$comment = $myrow [product_name] . ": " . number format ( $myrow [product_count] / $ GET [counts], 2 ) * 100 . "%"; 
/输出 柱 形 图 

imageTTFText ( $image, 15, 0, 390. 18 + 20 * $m, $color [0] [$m], $fnt, $comment ); 。 // 写 TTF 文字 到 图 中 


imagepng ( Simage ); 
7 (Simage ); 
(3) 编写 conn 文件 夹 ， 定 义 conn.php 文件 ， 连 接 MySQL 数据 库 服 务 器 ， 连 接 db_database06 数据 库 ， 并 
设置 数据 库 编码 格式 为 UTF-8。 


国 秘笈 心 法 

心 法 领悟 313: for 循环 语句 和 while 循环 语句 在 输出 相同 数据 时 的 区 别 。 

同时 应 用 for 循环 语句 和 while 循环 语句 输出 数据 库 中 存储 的 数据 ， 如 果 定 义 变量 $i 的 初始 值 为 0， 那么 在 
for 循环 语句 中 ，$i 的 第 一 个 值 是 0， 而 在 while 循环 语句 中 ，$i 的 第 一 个 值 是 1。 这 就 是 本 实例 中 将 $m 的 初始 


值 设置 为 -1 的 原因 ， 只 有 这 样 才能 保证 Sm 与 $i 的 值 是 统一 的 ， 以 获取 相同 的 颜色 值 。 如 果 将 $m 与 $i 的 初始 值 
都 设置 为 0， 那么 输出 的 饼 形 图 区 块 的 颜色 将 与 柱 形 图 区 块 的 颜色 不 同 。 
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类 的 定义 

类 的 访问 修饰 符 
类 的 继承 
抽象 类 和 接口 
类 的 多 态 

常用 关键 宁 
魔术 方法 
设计 模式 


面向 对 象 


第 7 章 面向 对 象 
7.1 类 的 定义 


采用 PHP 面向 对 象 的 编程 方式 ， 首 先 需要 对 类 进行 定义 。 类 是 对 象 的 模板 ， 所 以 要 定义 规范 、 合 理 的 类 结 
构 首先 应 该 明确 类 应 该 具有 的 属性 和 方法 ， 本 节 将 通过 具体 的 实例 讲解 类 的 定义 方法 。 


实例 314 


力 实例 说 明 
运行 本 实例 ， 效 果 如 图 7.1 所 示 。 首 先 在 图 中 的 文本 框 内 输入 连接 MySQL 数据 库 服务 器 所 需 的 必要 参数 ， 
然后 单 击 “连接 ”按钮 即 可 建立 与 指定 的 MySQL 数据 库 服务 器 的 连接 ， 并 将 连接 结果 打印 在 页 面 中 。 


并 所 a 

| 打印 连接 结果 
/下 | 

数据 库 秆 按 成 功 ! 


7.1 数据 库 连接 成 功 


力 关键 技术 


类 是 对 事物 的 抽象 ， 在 对 类 进行 定义 时 ， 合 理 地 设置 类 的 属性 和 方法 比较 重要 。 例 如 在 本 实例 所 应 用 的 数 
据 库 连接 类 中 ， 将 数据 库 服务 器 地 址 、 数 据 库 服 务 器 用 户 名 和 密码 、 数 据 库 名 称 以 及 数据 库 字符 集 作 为 类 的 属 
性 保存 ， 而 将 数据 库 连 接 的 实现 过 程 定义 为 类 的 方法 ， 这 是 因为 数据 库 连 接 参 数 在 类 的 生命 周期 内 基本 没有 变 
化 ， 而 且 属 于 特性 范围 ， 所 以 定义 为 类 的 属性 ， 而 数据 库 连 接 方法 属于 类 的 动作 或 功能 ， 所 以 定义 成 类 的 方法 。 

在 PHP 5.0 以 前 的 版 本 中 ， 类 属性 使 用 关键 字 dim 声明 ， 通 过 该 关键 字 声 明 的 类 属性 可 以 在 类 声明 周期 的 
任何 范围 内 被 调用 。 而 在 PHP 5.0 以 后 版 本 中 ， 引 入 了 public、protected 和 private 关键 字 对 类 中 的 属性 或 方法 
进行 声明 ， 这 样 根据 不 同 的 关键 字 将 类 的 属性 或 方法 划分 为 公有 成 员 、 保 护 成 员 和 私有 成 员 3 种 ， 其 中 不 同 关 
键 字 修饰 的 类 成 员 的 说 明和 区 别 如 下 : 

Public: 表示 该 成 员 可 以 在 任何 范围 被 调用 ， 包 括 类 体内 部 、 该 类 的 子 类 和 类 实例 的 对 象 。 

Protected: 表示 该 方法 可 以 在 类 中 或 该 类 的 子 类 中 被 调用 。 

加 ”Private: 表示 该 类 只 能 在 类 体内 被 调用 。 


[说 明 : 如 果 没 有 对 类 中 方法 指定 任何 访问 权限 ，PHP 会 默认 该 方法 的 访问 权限 为 public。 
图 设计 过 程 
实现 本 实例 ， 首 先 需 要 定义 数据 库 连 接 类 ， 然 后 建立 数据 库 参数 录入 表单 来 指定 数据 库 连接 时 所 需要 的 连 


接 参 数 ， 下 面具 体 讲解 该 数据 库 连 接 类 的 设计 和 实现 过 程 。 
(1) 定义 数据 库 连接 类 , 并 通过 类 的 属性 保存 连接 MySQL 数据 库 所 需 的 参数 ,该 类 的 具体 实现 代码 如 下 : 


人 
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class ConnDb 
{ 
private $host; /MySQL 数据 库 服 务 器 地 址 
private $usemame; /用 户 名 
private Spassword: /密码 
/数据 库 编 码 
Private $dbname; /类 据 库 的 名 称 
public function __construct ($host, S$usemame, $password, $dbname, $charset = utf-8) /构造 方式 实现 类 的 初始 化 
区 
S$this->host = $host: // 初 始 服务 器 地 址 
S$this->username = $username; // 初 始 用 户 名 
Sthis->password = $password; // 初 始 用 户 密码 
Sthis->dbname = $dbname:; 
S$this->charset = $charset; // 初 始 数据 库 字符 集 
} 
public function getConnId 0 /数据 库 连 接 方法 
@$connId = mysql_connect($this->host, $this->usemame, $this->password); // 获 得 数据 库 连 接 句 柄 
@mysql_seleet_db(Sthis->dbname, Seonn1d); 
@mysql_query('set names ' . $this->charset); // 设 置 字符 集 
return $connld; /返回 连接 句柄 


} 


} 

上 述 代 码 中 ， 定 义 了 $host、$username、$password、S$charset 和 $dbname 5 个 私有 属性 ， 分 别 用 来 保存 数据 
库 服务 器 的 主机 地 址 或 名 称 、 数 据 库 服 务 器 用 户 名 、 用 户 密码 、 字 符 集 和 要 连接 的 数据 库 名 ， 并 通过 构造 方法 
__construct() 实 现 数 据 库 连 接 参 数 的 初始 化 ， 最 后 定义 getConnId0 方 法 返回 数据 库 连接 句柄 。 

(2) 建立 数据 库 连接 参数 录入 表单 ， 该 过 程 通过 HTML 语言 的 表单 标签 实现 ， 具 体 实现 代码 详 见 本 书 
光盘 。 

(3) 当 单 击 数据 库 参 数 录入 表单 中 的 “连接 ”按钮 时 ， 将 会 使 用 如 下 代码 判断 是 否 成 功 连接 数据 库 ， 


iflisset($ ] ET Dt 
require 'ConnDb.php'; // 包 含 数据 库 连 接 类 文件 
$connDb = new ConnDb($_ POST[host].$_POST[username'],$_POST[password].S En $ POST['charset]); /实例 数据 库 连 接 类 
echo !$connDb->getConnId0?' 数 据 库 连 接 失败 ! "数据 库 连接 成 功 ! 打印 连接 结果 


} 

上 述 代码 首先 通过 isset($_POST['host]) 判 断 用 户 是 否 已 经 提交 了 表单 ， 如 果 是 ， 则 使 用 require 语句 包含 数 
据 库 连 接 类 ， 然 后 使 用 new 关键 字 实例 该 类 ， 并 通过 调用 类 中 的 getConnId0 方 法 返回 数据 库 连 接 状 态 ， 最 后 打 
印 出 连接 结果 。 

力 秘笈 心 法 

心 法 领悟 314: 用 @ 屏 蔽 运行 期 错误 。 

在 程序 运行 时 ， 有 时 会 难以 避免 地 出 现 运行 期 错误 并 在 页 面 中 打印 错误 信息 ， 这 样 不 仅 会 使 页 面 的 友好 性 
大 打折 扣 ， 而 且 还 会 为 程序 带 来 极 大 的 安全 隐患 。 使 用 try/catch 语句 可 以 屏蔽 运行 期 错误 ， 不 过 需要 书写 的 代 


码 量 相对 较 大 。PHP 提供 了 @ 关 键 字 来 屏蔽 运行 期 错误 ， 只 要 在 可 能 发 生 运行 期 错误 的 代码 前 加 上 “@” 即 可 ， 


例如 ， 本 实例 用 来 屏蔽 连接 数据 库 失败 时 的 错误 提示 代码 如 下 : 
@$connId = mysql_connect($this->host, $this->usemame. Sthis->password): /获得 数据 库 连接 句柄 


义 数据 库 连接 方 法 初级 


实例 315 


国 实例 说 明 


使 用 PHP 的 MySQL 函数 库 管理 MySQL 数据 库 时 ， 首 先 需 要 获得 数据 库 连接 句柄 ， 然 后 才能 进一步 进行 
增 、 删 、 改 、 查 操作 。 运 行 本 实例 ， 首 先 在 图 7.2 所 示 的 表单 中 输入 数据 库 连 接 参数 ， 然 后 单 击 “ 连 接 ” 按 钮 ， 
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如 果 成 功 连接 上 MySQL 数据 库 ， 则 会 在 页 面 中 打印 出 数据 库 连 接 句柄 。 


庄 连 接 类 的 友 
服 和 地 址 icast 一 ] 
Ng er 
Ei esee 
数据 库 名 称 : [Wasvavasen7 | 


打印 连接 句柄 


连接 句柄 为 Resource id #3 


图 7.2 打印 连接 句柄 


图 关键 技术 


在 PHP 面向 对 象 的 编程 方式 中 ， 如 函数 被 定义 在 类 中 ， 就 称 之 为 成 员 方法 ， 成 员 方法 的 功能 应 该 匹配 该 类 
的 特定 功能 。 

类 中 定义 的 成 员 方法 不 能 出 现 重 名 的 情况 ， 并 且 需 要 注意 以 下 几 点 : 

加 ”函数 名 称 不 区 分 大 小 写 ， 如 myfun0 与 Myfun0) 指 的 是 同一 个 函数 。 

回 ”函数 的 参数 没有 限制 ， 可 以 定义 任意 个 需要 的 参数 。 

回 ”函数 名 称 理论 上 可 以 使 用 汉字 ， 但 汉字 是 双 字 节 字 符 ， 为 了 避免 出 现 无 法 预知 的 问题 ， 尽 量 不 使 用 。 


图 设计 过 程 
(1) 定义 数据 库 连接 类 ， 在 类 中 定义 数据 库 连 接 的 方法 getConnId0， 实 现 该 过 程 的 代码 如 下 : 

public function getConnId 0 /| 数据库 连接 方法 

{ 
@$connId = mysql_connect($this->host, $this->username, $this->password); // 获 得 数据 库 连接 句柄 
@mysql_sclect_db(Sthis->dbname, $connld); 
@mysql_query('set names ' . $this->charset); 1/ 设置 字 符 集 
return $connld; // 返 回 连 接 句 柄 


} 
在 上 述 方法 中 , 首先 通过 mysql_connect0 函 数 获得 数据 库 连 接 句 柄 , 然后 使 用 mysql_select_db0 〇 函数 选择 要 
连接 的 数据 库 ， 并 使 用 mysql_query0 函 数 执行 查询 语句 来 设置 数据 库 的 字符 集 。 


(2) 实例 数据 库 连接 类 ， 并 打印 连接 句柄 ， 实 现代 码 如 下 : 
$connDb =new ConnDb($_POST['host], $_POST['usemame'], $ POST[password].$_ POST['dbname],$_ POST['charset]); /实例 数据 库 连 接 类 
echo !SconnDb->getConnId0? 数 据 库 连接 失败 ! ': 数 据 库 连接 成 功 ! <br> 连 接 句 柄 为 'SconnDb->getConnld0: /打印 连接 句柄 


国 秘笈 心 法 


心 法 领悟 315: 通过 set names utf8 语句 动态 设置 数据 库 的 字符 集 为 UTF-8 编码 。 

在 对 数据 库 内 容 进行 检索 输出 时 ， 有 时 可 能 会 出 现 乱码 现象 一般 都 是 由 数据 库 字 符 集 设置 存在 偏差 所 致 ， 
为 了 避免 上 述 情 况 的 发 生 ， 可 以 在 执行 数据 库 查询 语句 前 执行 “set names 编码 ”语句 ， 在 开发 项 目 时 ， 为 了 便 
于 国际 化 ， 建 议 应 用 UTF-8 编码 。 


< 注意 : 设置 MySQL 数据 库 为 UTF-8 编码 所 执行 的 语句 应 该 为 set names utf8， 而 非 set names utf8， 即 utf 
和 8 之 间 没 有 “-”。 
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| | 实例 说 明 请 输入 一 组 数字 ， 和 要求 用 半角 远 号 分 划 | | 
运行 本 实例 ， 效 果 如 图 7.3 所 示 。 首 先 在 图 7.3 的 文本 框 中 输入 一 组 数字 并 。 | Ee Bl 

用 半角 逗号 分 隔 , 然后 单 击 “计算 ”按钮 , 将 在 页 面 中 打印 出 该 组 数字 的 平均 值 。 waxswristwn 

图 关键 技术 图 73 计算 一 组 数 的 平均 值 


由 于 该 类 只 包含 一 个 用 于 计算 平均 数 的 方法 ， 所 以 在 实现 该 类 时 将 求 平均 数 的 方法 定义 为 静态 方法 ， 这 样 
在 不 实例 该 类 的 情况 下 通过 类 名 即 可 直接 调用 该 方法 。 
在 PHP 面向 对 象 编程 方式 中 ， 静 态 方法 隶属 于 某 个 类 ， 但 不 受 类 的 束缚 ， 可 以 直接 被 外 部 访问 。 与 定义 类 


中 普通 方法 相 比 ， 定 义 静态 方法 时 需要 使 用 static 关键 字 进行 修饰 ， 其 定义 格式 如 下 : 
public static function 方法 名 0) 


/该 方法 实现 的 功能 
} 
在 类 体内 部 调用 该 方法 时 ， 使 用 self 关键 字 加 “::” 调 用 ， 在 类 外 直接 使 用 类 名 加 “::” 引 用 。 
看 设计 过 程 
(1) 建立 数据 统计 类 Stat， 并 在 类 体内 定义 静态 方法 getAvg0 用 来 实现 求 多 个 数字 的 平均 值 ， 其 实现 代码 
如 下 : 
class Stat 
: public static function getAvg ($arryNum) // 定 义 静态 方法 求 平均 值 
y S$totalNum = count($arryNum); // 获 得 数字 总 数 
f($totalNum — 0) { /如 果 数 字 个 数 为 0， 则 返回 null 
return null; 
clse 
. a /用 变量 $sum 保存 所 有 数字 的 和 
for ($i=0; $i < StotalNum: $i++) { // 通 过 循环 计算 所 有 数字 的 和 
S$sum += $arryNum[$i]; 
i Ssum / $totalNum; // 返 回 平均 数 


} 
| } 
上 述 代码 用 于 实现 求 平均 数 的 getAvg( 方 法 中 ,为 了 能 够 实现 求 任意 个 数 数字 的 平均 数 ， 将 数组 作为 参数 ， 
这 样 只 要 求 得 该 数组 所 有 元 素 的 平均 值 即 可 ， 在 具体 实现 过 程 中 ， 首 先 使 用 函数 countO 计 算数 组 元 素 的 个 数 ， 
然后 使 用 for 循环 语句 计算 数组 中 所 有 元 素 的 和 ， 最 后 使 用 return 语句 返回 所 求 的 平均 数 。 
(2) 建立 数字 录入 表单 ， 当 用 户 单 击 表单 中 的 “计算 ”按钮 时 ， 将 通过 如 下 代码 计算 在 表单 中 录入 数字 的 


平均 数 。 
iflisset($_POST['nums']) && trim($_POST[numsD)!="){ // 判 断 是 否 已 经 提交 表单 
require 'Stat php': // 包 含 数据 统计 类 
S$arrayNum = explode(',. $_ POST[nums]): // 将 提交 数字 保存 到 数组 中 
echo ' 该 组 数字 的 平均 数 为 ' . Stat:getAvg($arrayNum): // 调 用 统计 类 的 静态 方法 getAvg0 求 平均 数 


} 

上 述 代码 首先 判断 用 户 是 否 提交 了 表单 ， 如 果 是 ， 则 首先 使 用 require 语句 包含 数据 统计 类 ， 然 后 使 用 函 
数 explode0 用 半角 逗号 分 隔 提交 的 数字 字符 串 ， 最 后 调用 数据 统计 类 的 静态 方法 getAvg0 计 算 所 录入 数字 的 平 
均 数 。 
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[上 说 明 :， explode0 函 数 用 于 实现 将 字符 串 以 指定 的 字符 或 子 串 分 隔 ， 并 将 分 隔 结果 保存 到 数组 中 。 


心 法 领 司 316: 为 了 提高 代码 运行 效率 ， 建 议 将 count0 函 数 放 在 循环 体外 。 


本 实例 计算 数组 中 所 有 元 素 的 和 可 以 有 两 种 写法 ， 分 别 如 下 : 


将 count0 函 数 写 在 for 循环 体内 : 
for($i=0; $i<count($arrayNum); $i++){} 

回 ”将 count0 函 数 写 在 for 循环 体外 : 
$count = count($arrayNum):; 

for($i=0; $i<$count; $i++){} 


查看 上 述 两 种 写法 可 知 ， 第 一 种 写法 在 执行 每 次 循环 时 都 需要 执行 一 次 count0 函 数 ， 而 第 二 种 写法 只 在 执 


图 实例 说 明 


本 实例 通过 使 用 类 的 方法 重 载 机 制 ， 实 现 不 同类 型 数据 的 运算 。 运 行 本 实例 ， 效 果 分 别 如 图 7.4 和 图 7.5 所 
示 。 其 中 ， 图 7.4 展示 的 是 两 个 数值 型 数据 求 和 的 计算 结果 ， 图 7.5 展示 的 是 两 个 字符 串 连 接 的 结果 。 


请 给 入 要 统计 的 内 容 : 请 给 入 要 统计 的 内 写 ， 
区 ] Eamaw | 
下 ] [和 ] 
Ja 六 + 
抗 计 结 时 为 ，30 统计 绍 内 为， 巨 克 腾飞 ， 明 日 升 起 。 
7.4 ”两 个 数字 求 和 的 结果 7.5 ”两 个 字符 串 连接 的 结果 


力 关键 技术 

本 实例 主要 应 用 PHP 面向 对 象 编程 中 的 方法 重 载 实 现 。 通 过 方法 重 载 机 制 ， 可 以 在 子 类 中 定义 与 父 类 同样 
的 方法 ， 然 后 对 该 方法 内 部 功能 代码 进行 重新 编写 ， 这 样 就 实现 了 方法 重 载 。 通 过 方法 重 载 可 以 扩展 或 弥补 原 
父 类 方法 的 缺陷 或 不 足 ， 进 一 步 扩 展 类 中 方法 的 功能 。 

例如 ， 已 经 定义 了 较为 复杂 的 汽车 类 Car， 并 在 其 内 部 定义 了 变速 行驶 的 方法 ， 代 码 如 下 : 

class Car 


public function changeSpeedO /变速 的 方法 
{ 
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// 实 现 手动 变速 的 功能 
// 其 他 方法 


} 

分 析 上 述 代码 可 知 ， 其 中 的 变速 方法 只 能 实现 “手动 变速 ”的 功能 ， 那 么 如 果 汽 车 经 过 改装 可 以 实现 自动 
变速 了 ， 是 不 是 该 Car 类 就 需要 完全 重新 编写 呢 ? 其 实 并 不 需要 这 样 ， 只 要 编写 该 类 的 子 类 ， 然 后 在 子 类 中 重 
写 changeSpeed0 方 法 即 可 ， 实 现 该 过 程 的 示例 代码 如 下 : 

class NewCar extends Car 

{ 

en 
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这 条 件 D{ 
/实现 手动 变速 的 功能 


jelsef 
/实现 自动 变速 的 功能 
} 


} 
// 其 他 方法 


} 

经 过 对 上 述 changeSpeed() 方 法 的 重 写 ， 就 可 以 使 该 方法 既 具 有 手动 变速 又 具有 自动 变速 的 功能 ， 从 而 可 以 
缩短 程序 开发 周期 ， 节 约 维护 时 间 。 
图 设计 过 程 

(1) 首先 建立 数据 统计 类 父 类 ， 并 在 该 类 中 定义 统计 方法 execStat0， 父 类 所 定义 的 统计 方法 只 有 计算 两 
个 数 的 和 的 功能 ， 其 实现 代码 如 下 : 

class StatParent // 定 义 数据 统计 父 类 

- public function execStat ($var0, $varl) // 定 义 数据 统计 方法 

return intval(Svar0 + $varl); // 返 回 两 个 数 的 和 


} 
(2) 定义 类 Stat 并 使 该 类 继承 自 StatParent 类 ， 在 该 类 体内 重 写 统计 方法 execStat 中 ,使 该 方法 根据 传递 的 
参数 类 型 种 类 来 同时 实现 数值 型 的 求 和 及 字符 串 型 的 连接 功能 ， 代 码 如 下 : 


require 'StatParent.php'; 
class Stat extends StatParent 


public function execStat ($var0, $varl) // 重 写 数据 统计 方法 
{ 
retum is_numeric($var0) && is_numeric($varl) ? intval($var0 + $varl) : $var0 . $varl; // 如 果 为 数字 则 计算 数字 的 和 ， 否 则 连接 两 个 参数 
} 


[| 说 明 : 函数 is_numericO 用 于 判断 指定 的 内 容 是 否 为 数值 型 数据 或 数值 型 字符 串 。 


(3) 建立 数据 录入 表单 〈 该 表单 的 实现 代码 请 详 见 本 书 光 盘 ) ， 当 用 户 在 表单 中 录入 完 要 统计 的 数据 后 ， 
单 击 “ 统 计 ” 按 钮 ， 将 通过 如 下 代码 调用 数据 统计 类 的 execStat0 方 法 对 用 户 提交 的 内 容 进行 统计 。 


iflisset($_POST['txt1']) && $_POST['txt1]!="){ /判断 用 户 是 否 提交 了 表单 
require 'Stat.php'; // 包 含 数值 统计 类 
Sstat = new Stat(): /实例 数值 统计 类 
echo ' 统 计 结果 为 :'. $stat->execStat($_POST['txt1], $_POST[txt2; /| 输出 统计 结果 
} 
力 秘笈 心 法 


心 法 领悟 317: 使 用 条 件 运算 符 蔡 代 简 单 的 过 条 件 控制 语句 。 


在 编写 程序 时 ， 可 以 使 用 条 件 运 算 符 蔡 代 简单 的 过 条 件 控 制 语句 ，PHP 中 条 件 运 算 符 的 使 用 格式 如 下 : 
条 件 表达 式 ?表达 式 1: 表 达 式 2 


在 执行 条 件 运算 符 时 ， 首 先 计算 条 件 表达 式 的 值 ， 如 果 为 真 则 执行 表达 式 1， 反 之 执行 表达 式 2。 


初级 
趣味 指数 : 傅 良 庚 


实例 318 


力 实例 说 明 
本 实例 通过 Sthis 关键 字 在 汽车 类 内 部 , 调用 设置 汽车 颜色 的 方法 和 设置 汽车 品牌 的 方法 来 输出 汽车 的 信息 。 
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运行 本 实例 ， 如 图 7.6 所 示 ， 分 别 选中 表单 中 的 颜色 和 类 型 单 选 按钮 ， 然 后 单 击 “提交 ”按钮 即 可 在 页 面 中 打 
印 出 汽车 的 信息 。 


EF 
A&é: © Aé: © 黑 E: © fC 
请 加 择 夫 型, 

Nh: CO 3: © Ne © ié: © 
-过 | 

我 的 汽车 是 黑 和 宝马 


图 7.6 打印 汽车 信息 


图 关键 技术 


在 PHP 面向 对 象 编程 方式 中 ， 可 以 使 用 $this 关键 字 对 类 自身 的 属性 或 方法 进行 调用 。 例 如 ， 已 经 在 A 类 
中 定义 了 fun10 方 法 ， 在 该 类 的 fun20 方 法 中 可 以 使 用 如 下 方式 对 fun10 方 法 进行 调用 。 
class A 
: private function func10 
//fun10 方 法 实现 的 功能 
i 
Sthis->fun10; /调用 fun10 方 法 
} 
力 设计 过 程 
(1) 定义 汽车 类 Car。 首 先 在 该 类 中 定义 汽车 颜色 标识 和 汽车 类 别 标识 两 个 属性 ， 然 后 使 用 构造 函数 对 这 
两 个 属性 进行 初始 化 ， 并 在 类 内 定义 getColor0 方 法 和 getType0 方 法 ,分别 用 来 获取 汽车 颜色 和 汽车 类 型 ， 最 后 
使 用 getInfo0 方 法 打印 出 汽车 信息 。 本 实例 的 汽车 类 实现 代码 如 下 : 


class Car // 定 义 汽车 类 
{ 
Private $colorFlag; 1/ 颜色 标识 
Private $typeFlag: // 类 型 标识 
public function __constmct ($colorFlag, $typeFlag) // 构 造 方法 
{ 
Sthis->colorFlag = $colorFlag: 1/ 颜色 标识 初始 化 
Sthis->typeFlag = $typeFlag: // 类 型 标识 初始 化 
public function getColor 0 /定义 获取 颜色 方法 
{ 
‘switch ($this->colorFlag) { /使 用 switch 语句 根据 不 同 颜色 获得 标识 和 颜色 
case 0: 
Scolor = 红色: 
break; 
case 1: 
$color=' 白 色 
break: 
case 2: 
$color = ' 黑 色 ， 
break; 
default: 
$color =' 宝 石 蓝 
} 
return $color: 
K 
public function getType | /定义 获得 汽车 类 型 方法 
switch ($this->typeFlag) { /根据 类 型 标识 获得 汽车 类 型 
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} 
public function getInfo 0 /获得 汽车 信息 
retum ' 我 的 汽车 是 '. Sthis->getColor0 . Sthis->getType0; /调用 类 内 方法 返回 汽车 信息 


} 
(2) 建立 汽车 属性 选择 表单 ， 当 用 户 单 击 表单 的 “提交 ”按钮 后 接收 表单 提交 的 颜色 标识 和 类 别 标识 ， 然 
后 使 用 new 关键 字 对 汽车 类 进行 实例 化 , 最 后 使 用 实例 化 的 汽车 类 对 象 调用 该 类 的 getInfo0 方 法 打印 汽车 信息 ， 


其 代码 如 下 : 
iflisset($_POST['color]) &é& isset($_POST['type ]){ // 判 断 是 否 提 交 了 表单 
require 'Car.php’; // 包 含 汽车 类 
$colorFlag = $_POST['color]; /获得 表单 提交 的 颜色 标识 
StypFlag =$_POST['type']; // 获 得 表单 提交 的 类 别 标识 
Scar = new Car($colorFlag. $typFlag); /对 汽车 类 进行 实例 化 
echo $car->getInfo(); /打印 汽车 信息 
} 
力 秘笈 心 法 


心 法 领悟 318: 在 类 体内 部 使 用 $this 关键 字 可 以 调用 私有 、 保 护 和 公有 成 员 。 
PHP 面向 对 象 编程 方式 中 ， 在 类 体内 部 可 以 使 用 Sthis 关键 字 访 问 被 private、protected 和 public 所 修饰 的 属 
性 或 方法 。 
用 学 生 类 自身 的 静态 方法 初级 | 
趣味 指数 ; 容 宙 全 | 


实例 319 


实例 说 明 

本 实例 首先 定义 学 生 类 Student， 然 后 在 类 中 分 别 定义 学 习 和 读书 两 个 静态 方法 ， 同 时 在 类 中 定义 非 静态 的 
getAllMethod( 方 法 ， 通 过 该 方法 使 用 self 关键 字 调 用 学 习 和 读书 这 两 个 静态 方法 ， 在 类 外 分 别 使 用 类 名 和 实例 
的 对 象 调用 类 中 方法 输出 如 图 7.7 所 示 的 结果 。 


下 撕 岂 用 关 名 词 用 类 的 更 才 方法 学生 可 以 举 习 、 诺 书 
通过 类 号 调 用 类 中 方法 ， 学 生 可 以 学 习 、 读 蔬 


图 7.7 调用 类 中 的 静态 方法 


图 关键 技术 
PHP 面向 对 象 的 编程 方式 中 ， 可 以 使 用 self 关键 字 调用 类 中 的 静态 属性 或 方法 ， 调 用 格式 分 别 如 下 : 
class A 
a // 定 义 葛 态 属性 Svar 
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private static function fun0{ /定义 静态 方法 fun0 

} 

public function mainO{ /定义 公有 方法 main0 
self::Svar: // 引 用 静态 属性 
self::fanO; // 引 用 静态 方法 


:i 
了 
从 上 述 代 码 可 知 ， 在 类 体内 部 使 用 self 关键 字 加 “::” 引 用 类 中 的 静态 属性 或 静态 方法 。 
A 注意 :使 用 self 关键 字 调 用 类 的 静态 属性 时 不 要 遗漏 <“$?, 如 本 实例 中 的 引用 方法 为 self::$var, 而 非 self::var。 
设计 过 程 
(1) 定义 学 生 类 ， 在 类 中 定义 学 生 学 习 的 静态 方法 和 学 生 读 书 的 静态 方法 ， 同 时 定义 非 静 态 方法 
getAllMethod0， 并 在 该 方法 内 部 使 用 self 关键 字 调用 类 中 的 静态 方法 返回 学 生 可 以 完成 的 活动 ， 代 码 如 下 : 


class Student 
: Public static function study 0) /定义 学 习 方法 
retum "学 习 ' 
static function read 0) /定义 读书 方法 
retum ' 读 书 '; 
2 function getAlIMethod | /定义 getAlIMethod0 获 得 类 中 所 有 方法 


retum "学 生 可 以 '. self:study0 .'、'. self::read0; 
} 


(2) 使 用 require 语句 包含 Student.php 文件 ， 然 后 分 别 使 用 类 名 和 实例 的 对 象 调用 类 中 的 静态 方法 和 
getAllMethod() 方 法 打印 学 生 可 以 进行 的 活动 ， 代 码 如 下 ; 
< 


?php 
require 'Student php': /包含 Student.php 文件 
2 


<font color="red"> 

// 直 接 使 用 类 名 调用 类 的 静态 方法 

学 生 可 以 <?php echo Student::study0?>、<?php echo Student::read0?></font><br/> 
<font color="blue"> 

// 通 过 类 对 象 调用 类 中 方法 

<?php 


$student = new Student(); // 对 学 生 类 进行 实例 化 
echo $student->getAllMethodO; // 调 用 学 生 类 的 getAlIMethod( 方 法 
?> 


力 秘笈 心 法 


心 法 领悟 319: 使 用 类 名 调用 类 中 静态 方法 ， 将 不 执行 构造 方法 。 
通过 类 名 可 以 直接 调用 类 中 的 静态 方法 ， 那 么 此 时 是 否 会 执行 构造 方法 _constmct0 呢 ? 请 看 如 下 代码 : 


class A 
public function _constrmct () // 构 造 方法 
echo ' 构 造 方法 '; 
a static function fun | // 静 态 的 fun0 方 法 
echo ‘funO)'; 
ee // 通 过 类 名 调用 静态 的 fun0 方 法 
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运行 上 述 代码 将 输出 fn0， 而 没有 输出 构造 方法 中 的 内 容 ， 当 使 用 new 关键 字 对 类 进行 实例 化 后 将 执行 构 
造 方法 。 


实例 320 趣味 指数 : 但 福全 


力 实例 说 明 


本 实例 主要 实现 通过 实例 后 类 的 对 象 调用 类 的 属性 和 方法 。 运行 本 实 全 于 各 和 一 沪 夺 的 人 了 和 年 力 法 
例 ， 如 图 7.8 所 示 ， 通 过 调用 汽车 类 的 颜色 属性 打印 汽车 颜色 ， 通 过 调用 


汽车 类 的 刹车 方法 执行 刹车 操作 。 tli 
力 关键 技术 


类 实例 后 的 对 象 不 仅 可 以 调用 类 的 公有 方法 ， 而 且 可 以 调用 类 中 的 公有 属性 ， 其 调用 格式 如 下 : 
a 
图 设计 过 程 
(1) 定义 汽车 类 ， 在 该 类 中 定义 汽车 颜色 属性 和 汽车 刹车 的 方法 ， 并 通过 构造 方法 对 汽车 颜色 属性 进行 初 
始 化 ， 其 实现 代码 如 下 : 


class Car 
{ 
public $color: /汽车 颜色 属性 
public function __construct($colon){ // 构 造 方法 
S$this->color = $color; /汽车 颜色 初始 化 
} 
public function stopO{ // 定 义 汽车 刹车 方法 
retum "汽车 执行 了 刹车 方法 "; 


} 
} 


4 注意 : 为 了 能 够 在 类 体外 引用 类 的 颜色 属性 ， 需 要 将 颜色 属性 声明 为 公有 属性 。 


(2) 使 用 require 语句 在 index.php 文件 中 包含 Car.php 文件 ， 并 对 汽车 类 进行 实例 化 ， 同 时 指定 汽车 类 
的 颜色 属性 值 为 红色 ， 最 后 使 用 实例 化 的 对 象 通过 符号 “->” 调 用 汽车 类 的 颜色 属性 和 刹车 方法 ， 代 码 如 下 : 


<2php 
require 'Car.php'; 
> 


<font color="blue"> 


S$car = new Car($color): 

echo 汽车 的 颜色 为 一 '. $car->color.'<br/>'; 
echo ' 行 驶 过 程 中 一 ，. $car->stop0; 

> 


国 秘笈 心 法 


心 法 领悟 320: 使 用 $this 引用 类 的 属性 时 ， 请 注意 “$” 的 位 置 。 
引用 类 内 的 属性 时 ，“$” 应 该 放 在 this 前 ， 即 $this->var， 而 非 this->$var。 


~ w+ 


实例 321 


力 实例 说 明 


本 实例 采用 二 维 数组 模拟 数据 库存 储 学 生 信息 , 然后 通过 for 循环 语句 实例 学 生 类 , 并 通过 构造 方法 为 学 生 
类 的 属性 赋 初 值 ， 最 后 通过 类 的 i di 并 将 学 生 信 息 在 页 面 输出 ， 如 图 7.9 所 示 。 


0312310 小 明 16 北京 区 城区 


0312311 少 张 16 北京 朝阳 区 
0312312 小 赵 17 北京 海淀 区 


图 7.9 学 生 信息 列表 


图 关键 技术 


构造 方法 是 类 中 的 一 个 特殊 函数 ， 当 创建 一 个 类 的 实例 时 ， 将 会 自动 调用 类 的 构造 方法 。 在 PHP 5.0 以 前 
的 版 本 中 ， 构 造 方法 名 称 与 类 名 相同 ， 而 在 PHP 5.0 以 后 的 版 本 中 统一 使 用 _construct0 作 为 构造 方法 名 称 ， 使 
用 构造 方法 时 应 该 注意 以 下 两 点 : 

加 ”构造 方法 没有 返回 值 类 型 和 返回 值 ， 这 是 因为 构造 方法 是 在 创建 对 象 时 自动 调用 的 ， 并 不 是 一 个 独立 

的 函数 ， 因 此 不 需要 返回 值 。 
加 ”构造 方法 的 主要 功能 是 实现 对 类 的 初始 化 工作 。 


图 设计 过 程 
(1) ed 用 来 模拟 数据 库 ， 代 码 如 下 : 
S$students = // 二 维 数组 ， 模 拟 数 据 库 


人 "小 明 ','16', 北京 西城 区 ) , 
1 => array(0312311',' 小 张 ,'16"', "北京 朝阳 区 ) ， 
2 => array(0312312', "小 赵 ', 17', "北京 海淀 区 ) 
六 
(2) 定义 学 生 类 Student， 在 该 类 中 使 用 构造 方法 _construct0 实 现 对 学 生 信息 的 初始 化 ， 然 后 针对 类 的 各 
个 属性 建立 相应 的 getXxx0 方 法 获取 属性 的 值 ， 代 码 如 下 : 


class Student 
{ 
Private $id; /| 学 生 思 
Private $name; // 学 生 名 称 
private $age; // 学 生年 龄 
private $address; 1/ 学生 住址 
public function __construct ($id, $name, $age, $address) // 构 造 方法 ， 对 学 生 信息 初始 化 
{ 
Sthis->id = $id; 
S$this->name = $name: 
S$this->age = $age; 
Sthis->address = $address: 
} 
public function getId | // 获 得 学 生 也 
retumn $this->id: 
} 
public function getName | // 获 得 学 生 名 称 
{ 
retum $this->name; 


了 
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public function getAge (0 /获得 学 生年 龄 
Tetum $this->age; 

function getAddress | // 获 得 学 生 住址 
. Teturn $this->address; 


} 
(3) 通过 for 循环 语句 遍历 保存 学 生 信息 的 $students 数组 ， 遍 历 过 程 中 将 学 生 信息 保存 到 Student 学 生 类 
中 ， 并 通过 该 类 实例 的 对 象 调用 类 中 相应 的 getXxx0 方 法 ， 获 取 学 生 信息 。 实 现 该 过 程 的 代码 如 下 : 


require ‘Student.php'; 
S$count = count($students); 


?> 
<table border="0" align="center" cellpadding="0" cellspacing="1" bgeolor="#009933"> 
<b> 
<td width="100" height="22" bgeolor="#009933"><font color="#FFFFFF"> 学 号 </font></td> 
<td width="100" bgeolor="#009933"><font color="#FFFFFF"> 姓 名 </font></td> 
<td width="100" bgeolor="#009933"><font color="#FFFFFF"> 年 龄 </font></td> 
<td width="200" bgcolor="#009933"><font color="#FFFFFF"> 住 址 </font></td> 
< 


<?php 
for ($i=0; Si<$count; Si++j{ 
Sstu = $students[$i]; 
S$student = new Student($stu[0], $stuf1], $stu[2], $stu[3]); 
人 
<tr> 
<td height="22" bgcolor="#FFFFFF"><?= Sstudent->getld0?><ltd> 
<td bgcolor="#FFFFFF"><?= $student->getName()?></td> 
<td bgcolor="#FFFFFF"><?= $student->getAgeO?></td> 
<td bgcolor="#FFFFFF"><?= $student->getAddressO?></td> 
<t> 
<?php 
} 
> 


力 秘笈 心 法 


心 法 领悟 321: PHP 5.0 中 构造 方法 名 称 以 双 下 划 线 开头 。 
在 使 用 PHP 5.0 的 构造 方法 时 ， 一 定 要 注意 构造 方法 _construct0 是 以 双 下 划 线 开头 ， 而 非 单 下 划 线 。 


ss 二 Cs | 
趣味 指数 : 请 寅 庚 | 


国 实例 说 明 


计算 加 面积: 


本 实例 实现 的 功能 是 根据 圆 的 半径 计算 圆 的 面积 ,运行 结果 ， 如 图 710 所 | xsxanrs. 6 ss 
示 。 首 先 在 图 中 的 文本 框 内 输入 要 计算 的 贺 面 积 的 半径 ， 然 后 单 击 “ 计 算 ” 按 “| sanmaw ea 
钮 即 可 计算 出 圆 的 面积 ， 并 将 结果 打印 在 页 面 中 。 大 本 新 呈 曾 和 


图 关键 技术 


本 实例 的 关键 是 通过 类 常量 保存 圆 的 半径 ， 然 后 在 类 的 方法 中 对 该 常量 进行 调用 。 下 面 介绍 PHP 面向 对 象 
编程 方式 中 类 常量 的 定义 和 引用 方法 。 
PHP 的 全 局 常量 可 以 使 用 define0 函 数 定义 ， 例 如 : 
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define(PT, 3.17); // 定 义 常量 PI 
Sradius = 2; // 指 定 圆 半径 
echo ' 圆 面积 为 :'. PI * pow($radius. 2); /| 计算 圆 面积 


在 上 述 代码 中 首先 使 用 define0 函 数 定义 圆周 率 常量 PI， 然 后 指定 圆 半 径 为 2， 最 后 在 计算 圆 面积 的 表达 式 
中 调用 常量 PI 计算 圆 面积 。 

而 在 PHP 5.0 以 后 的 面向 对 象 编程 方式 中 引入 了 类 常量 的 概念 ， 类 常量 属于 类 本 身 而 且 区 分 大 小 写 ， 在 类 
体内 与 静态 成 员 类 似 ， 都 使 用 self 关键 字 加 “::” 对 类 常量 进行 引用 ， 如 本 实例 所 定义 的 圆 类 中 通过 如 下 代码 使 
用 类 常量 计算 圆 面积 。 


class Circle 


{ 
const PL ="'3.14'; /定义 圆周 率 为 3.14， 也 可 以 使 用 pi0 函 数 
:省略 部 分 代码 
public function getArea 0 
{ 


// 获 取 贺 面积 
return self::PI * pow(S$this->radius, 2); 
} 
} 
从 上 述 代 码 可 知 ， 类 常量 使 用 const 关键 字 声明 ,与 全 局 常量 类 似 ， 习 惯用 大 写字 母 表示 ， 在 类 的 方法 中 使 
用 self:: 调 用 。 


力 设计 过 程 
(1) 定义 圆 类 ， 首 先 将 圆周 率 保存 在 类 常量 PI 中 ， 然 后 定义 私有 方法 Sradius 用 于 保存 圆 的 半径 ， 最 后 定 
义 类 的 公有 方法 getArea0 来 计算 圆 的 面积 ， 实 现代 码 如 下 : 


class Circle 

{ 
const PL ="3.14'; /定义 圆周 率 为 3.14， 也 可 以 使 用 pi0 函 数 
Private $radius; / 圆 半径 
public function __ constmct ($radius) /构造 方法 ， 实 现 对 圆 半径 初始 化 


Sthis->radius = Sradius; 
3 
public function getArea 0) /获取 圆 面积 


return self::PI * pow($this->radius, 2); 
} 


} 
(2) 建立 圆 半 径 录 入 表单 〈 该 过 程 的 实现 代码 详 见 本 书 光盘 ) ， 在 表单 中 录入 圆 半径 后 ， 单 击 “ 计 算 ” 按 
钮 即 可 计算 圆 面积 并 打印 计算 结果 ， 代 码 如 下 : 


if (isset($_POST['radius']) && trim($_POST[radius])!="){ 1/ 判断 是 否 提交 了 表单 
require_once 'Circle.php'; // 包 含 贺 类 
Scircle = new Circle($_POST['radius']); // 对 贺 类 进行 实例 化 
echo ' 该 圆 的 面积 为 ;'.$circle->getArea0; /打印 计算 结果 
} 
图 秘笈 心 法 


心 法 领悟 322: 使 用 pow0 函 数 计算 指定 数值 的 n 次 方 宕 。 
在 PHP 编程 中 ， 经 常会 计算 某 个 数 的 n 次 方 究 ，PHP 提供 了 pow0 函 数 用 于 计算 某 个 数 的 n 次 方 寒 ， 该 函 
数 的 语法 格式 如 下 : 


number pow (number base, number exp) 

参数 说 明 : 

base: 要 计算 的 数值 。 

exp: 朝 数 。 

该 函数 用 于 计算 数值 base 的 exp 次 寡 的 值 ， 如 果 不 能 计算 ， 则 会 发 出 一 条 警告 并 返回 FALSE 值 。 
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7.2 类 的 访问 修饰 符 


在 PHP 5.0 以 前 的 版 本 中 ， 所 有 类 成 员 被 视 为 公有 成 员 ， 即 在 类 体内 、 类 的 子 类 中 以 及 类 实例 后 的 对 象 均 
可 被 调用 ， 而 在 PHP 5.0 以 后 的 版 本 中 ， 引 入 了 私有 成 员 、 保 护 成 员 和 公有 成 员 的 概念 ， 从 而 使 得 PHP 面向 对 
象 的 编程 方式 更 为 成 熟化 。 


Dic 关键 字 定 义 汽车 的 行驶 方法 中 级 | 
23 起 味 指数 : 计 良 寥 


实例 323 


图 实例 说 明 


本 实例 用 于 展示 在 类 体外 、 类 内 部 的 方法 中 和 类 的 子 类 中 调用 被 public 关键 字 所 修饰 的 方法 的 结果 ， 如 
7.11 所 示 。 


(1) 通过 汽车 尖 对 象 词 有志 车 关 的 行 下 方法 的 结果 
行驶 
《2 和 这 次 年 类 的 entStatae0 万 法 调用 汽车 条 台 万 法 的 结果 : 
汽车 日前 正在 行驶 
3 通过 汽车 类 的 子 类 调用 汉 革 关 的 汽 革 对 方 法 的 嫩 具 : 
小 汽车 行驶 


图 7.11 被 public 关键 字 修饰 的 方法 在 不 同 范围 内 被 调用 


图 关键 技术 


在 PHP 5.0 面向 对 象 的 编程 中 ， 被 关键 字 public 修饰 的 方法 称 为 公有 方法 ， 公 有 方法 可 以 被 类 实例 的 对 象 
在 类 内 部 以 及 类 的 子 类 中 调用 。 


图 设计 过 程 
(1) 首先 建立 汽车 类 Car， 并 在 该 类 内 部 定义 汽车 行驶 方法 rn0 以 及 获得 汽车 状态 的 方法 getStatus0， 然 
后 定义 类 SmallCar， 使 该 类 继承 自 类 Car， 并 在 该 类 中 定义 smallCarRun0 方 法 。 实 现 该 过 程 的 代码 如 下 : 


class Car /定义 汽车 类 Car 
public function run (| // 定 义 行驶 方法 
， retum ' 行 驶 '; 
i function getStatus | /定义 返回 汽车 状态 方法 


{ 
retum "汽车 目前 正在 '. $this->run(); 
} 
// 定 义 小 汽车 类 SmallCar， 并 使 其 继承 汽车 类 Car 
class SmallCar extends Car 
public function smallCarRun (0) // 定 义 小 汽车 行驶 方法 


{ 
retum ' 小 汽车 ' . Sthis->run0): 
} 


} 
(2) 打印 在 不 同 范围 内 调用 汽车 类 的 行驶 方法 的 结果 ， 代 码 如 下 : 
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require'Carphp': 
车 new Car(); 

" (1) 通过 汽车 类 对 象 调用 汽车 类 的 行驶 方法 的 结果 : <br/>"; 
人 ‘<br/>'; 
echo' (2) 通过 汽车 类 的 和 sei0 力 流光 用 站 竺 们 法 的 全 和 
echo $car->getStatus() . " 
echo' (3) 法 的 结果: <br>' 
S$smallCar = new SmallC: 
echo SsmallCar >smallCerRunO cbp>' 


心 法 领悟 323: 合理 使 用 public 关键 字 修饰 类 体内 的 方法 。 
在 定义 类 的 时 候 ， 虽 然 使 用 public 关键 字 可 以 使 方法 在 类 的 生命 周期 的 任何 范围 内 被 访问 ， 但 是 不 要 将 类 
中 的 所 有 方法 都 定义 为 公有 ， 这 样 可 以 有 效 提高 程序 的 安全 性 和 商业 化 。 


力 实例 说 明 


本 实例 主要 通过 在 不 同 范围 内 调用 类 中 私有 属性 来 演示 私有 成 员 的 作用 范围 。 运 行 本 实例 ， 如 果 通 过 类 实 
例 后 的 对 象 直接 调用 类 的 私有 属性 ， 将 在 页 面 打印 如 图 7.12 所 示 的 错误 信息 ， 如 果 通 过 类 中 方法 调用 类 的 私有 


属性 将 输出 汽车 的 颜色 ， 如 图 7.13 所 示 。 


笨 过 类 实例 的 对 象 调用 尖 的 私有 属性 的 结果 ; 


aalerrer Cannotaceyes privite property Car $eokor 在 半 中 的 方法 中 调用 站 的 私 有 展 性 的 续 果 1 
in DAAppSev ww MROT OI ndexphp on Ens 17 汽车 颜色 是 ， 红色 
图 7.12 通过 对 象 调用 类 中 私有 属性 图 7.13 通过 类 中 方法 调用 类 的 私有 属性 


力 关键 技术 


在 PHP 5.0 面向 对 象 的 编程 中 , 被 关键 字 private 修饰 的 成 员 称 为 私有 成 员 , 私有 成 员 可 以 在 类 体内 被 调用 ， 
但 不 可 以 被 类 实例 的 对 象 和 类 的 子 类 所 调用 。 


力 设计 过 程 
(1) 首先 定义 汽车 类 Car， 在 汽车 类 中 定义 私有 属性 $color， 并 通过 构造 方法 为 $color 属性 进行 初始 化 ， 最 
后 定义 getColor() 方 法 返回 汽车 颜色 的 值 ， 该 过 程 的 实现 代码 如 下 : 


class Car /定义 汽车 类 Car 
: Private $color: /汽车 颜色 
public function __constrct ($color) // 构 造 方法 对 类 中 属性 初始 化 
S$this->color = $color: // 汽 车 颜色 初始 化 
Oe function getColor | /定义 获得 汽车 颜色 的 方法 
return $this->color // 返 回 汽车 颜色 


} 


} 
(2) 对 汽车 类 进行 实例 化 ， 并 指定 汽车 颜色 为 红色 ， 然 后 通过 实例 的 对 象 调用 汽车 类 中 的 getColor0 方 法 
获得 汽车 颜色 ， 该 过 程 的 实现 代码 如 下 : 
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require 'Car.php'; // 包 含 汽 车 类 
Scolor= ' 红 色 ': /| 指定 汽车 颜色 
Scar = new Car($color); 1/ 对 汽车 类 实例 化 


/lecho ' 通 过 类 实例 的 对 象 调用 类 的 私有 属性 的 结果 : <br/>'; 

/echo @ 汽 车 颜色 是 :'S$car->color'<br/>' or die(' 不 能 通过 类 的 对 象 调用 类 中 的 私有 方法 <br/>"); 
echo ' 在 类 中 的 方法 中 调用 类 的 私有 属性 的 结果 : <br/>': 

echo ' 汽 车 颜色 是 : "$car->getColor0).'<br/>'; /打印 汽车 颜色 


在 上 述 代码 中 ， 被 注释 的 代码 用 于 实现 通过 类 实例 的 对 象 调 用 类 中 私有 成 员 的 结果 ， 如 果 去 掉 注释 将 出 现 
如 图 7.12 所 示 的 错误 提示 ， 从 而 说 明 类 中 的 私有 方法 不 能 被 类 实例 的 对 象 所 调用 。 


心 法 领悟 324: 合理 定义 类 中 的 私有 方法 。 

由 于 私有 成 员 只 可 在 类 体内 被 访问 ， 所 以 在 定义 类 成 员 时 ， 不 准备 在 类 体外 及 该 类 的 子 类 中 引用 的 方法 ， 
应 该 定义 为 私有 方法 。 

如 果 打 算 在 类 体外 获得 某 属性 的 值 ， 建 议 将 该 属性 定义 为 私有 属性 ， 然 后 再 定义 一 个 公有 的 getXxx0 方 法 ， 
在 该 方法 中 使 用 retum 语句 返回 该 属性 的 值 ， 在 类 体外 只 要 通过 类 实例 的 对 象 调用 该 方法 即 可 获得 相应 私有 属 
性 的 值 。 


图 实例 说 明 


本 实例 主要 用 于 说 明 类 中 的 保护 成 员 在 不 同 范围 内 被 调用 的 结果 。 运 行 本 实例 ， 当 使 用 类 实例 的 对 象 调用 
类 中 的 保护 属性 时 ， 将 出 现 如 图 7.14 所 示 的 错误 提示 ， 然 后 注释 掉 通 过 类 对 象 调用 类 体内 保护 属性 的 代码 ， 并 
分 别 通过 在 类 体内 和 类 的 子 类 中 调用 类 的 保护 属性 ， 再 次 运行 该 实例 ， 将 出 现 如 图 7.15 所 示 的 页 面 。 


通过 此 实例 的 对 象 直接 调用 类 中 的 保护 起 员 的 结果 


在 尖 休 内 调用 保护 必 员 的 经 时 
Tatml error Cannor secess protected property 汽 革 课 信和 虹 为 : 3 年 
uc4apaaTine n DAAgpSe mon 在 光子 类 中 调用 保 六 民 员 的 结果 
tndexplp on tne 17 小 汽车 保全 限 为 ，; 生 
图 7.14 通过 对 象 调用 类 中 保护 成 员 图 7.15 通过 子 类 调用 父 类 的 保护 成 员 
力 关键 技术 


在 PHP 5.0 面向 对 象 的 编程 中 ， 被 关键 字 protected 修饰 的 成 员 称 为 保护 成 员 ， 保 护 成 员 可 以 在 类 体内 以 及 
类 的 子 类 中 被 调用 ， 但 不 可 以 在 类 体外 被 调用 。 


力 设计 过 程 
(1) 定义 汽车 类 Car 以 及 该 类 的 子 类 SmallCar。 在 汽车 类 中 定义 汽车 的 保修 时 间 属 性 ， 然 后 使 用 构造 方法 
对 该 属性 进行 初始 化 ， 同 时 定义 获得 汽车 保修 时 间 的 getRepairTime0 方 法 。 在 汽车 类 的 子 类 SmallCar 中 ， 使 用 


构造 方法 调用 其 父 类 的 构造 方法 ， 从 而 实现 对 父 类 的 保修 时 间 属 性 进行 初始 化 ， 最 后 在 SmallCar 类 中 定义 
getSmallCarRepairTime() 方 法 返回 汽车 的 保修 时 间 ， 实 现 该 过 程 的 代码 如 下 : 


class Car // 定 义 汽车 类 Car 
{ 
Pprotected $repairTime; /汽车 保修 时 间 属 性 
public function ”constmuct ($repairTime) /构造 方法 对 汽车 的 保修 时 间 进 行 初始 化 


时 
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Sthis->repairTime = S$repairTime; 
} 


public function getRepairTime 0 // 获 得 汽车 保修 时 间 的 方法 
{ 
Teturn $this->repairTime: 
} 
class SmallCar extends Car // 定 义 汽车 类 的 子 类 SmallCar 


{ 
public function __construct ($repairTime) 
+ 


Parent::_construct(SrepairTime); // 调 用 父 类 构造 方法 对 保修 时 间 属 性 进行 初始 化 
public function getSmallCarRepairTime () // 调 用 父 类 的 保修 时 间 属 性 
retum $this->repairTime: 


} 


bb 
(2) 使 用 new 关键 字 对 汽车 类 Car 进行 实例 化 ， 然 后 分 别 打 印 出 在 不 同 范围 内 调用 汽车 类 保护 属性 
SrepairTime 的 结果 ， 代 码 如 下 : 


require 'Car.php'; /包含 汽车 类 
SrepairTime = 3; // 定 义 保修 年 限 
Scar = new Car($repairTime): // 对 汽车 类 实例 化 


llecho "通过 类 实例 的 对 象 直 接 调 用 类 中 的 保护 成 员 的 结果 <br/>'; 

/lecho 汽车 保修 年 限 为 :，'.Scar->repairTime, 年 <br/>; 

echo ' 在 类 体内 调用 保护 成 员 的 结果 <br/>'; 

echo 汽车 保修 年 限 为 ，'.$Scar->getRepairTime0), 年 <br/>'; 

echo ' 在 类 子 类 中 调用 保护 成 员 的 结果 <br/>': 

SrepairTime = 5; // 定 义 保修 年 限 
SsmallCar = new SmallCar(SrepairTime); 

echo ' 小 汽车 保修 年 限 为 : '.$smallCar->getSmallCarRepairTime(), 年 <br/>'; 


国 秘笈 心 法 
心 法 领悟 325; 合理 定义 类 中 的 保护 成 员 。 
如 果 类 中 的 属性 或 方法 只 能 在 类 体 中 或 类 的 子 类 中 被 访问 ， 那 么 建议 将 该 类 定义 为 保护 成 员 。 
7.3 类 的 继承 


继承 性 是 类 的 主要 特点 之 一 ， 通 过 类 的 继承 可 以 扩展 父 类 的 功能 ， 本 节 将 通过 具体 实例 讲解 PHP 5.0 面向 
对 象 编程 方式 中 继承 的 应 用 方法 。 


so 中 级 
实例 326 起 于 可 才 :次 | 
力 实例 说 明 


本 实例 首先 定义 父 类 水 果 类 ， 并 在 该 类 中 定义 获得 水 果 颜 色 和 水 果 

形状 的 方法 ， 然 后 定义 水 果 类 的 子 类 苹果 类 ， 在 苹果 类 中 只 定义 构造 方 AFR EO 

法 用 于 实现 对 类 进行 初始 化 ， 然 后 通过 调用 父 类 的 方法 获得 苹果 的 颜色 A | 

和 形状 。 a 入 色 ， 国 的 
运行 本 实例 , 如 图 7.16 所 示 ， 首 先 在 表单 中 输入 苹果 的 颜色 和 形状 属 WE 

性 ， 然 后 单 击 “ 提 交 ” 按 钮 即 可 在 页 面 中 打印 出 苹果 的 颜色 和 形状 属性 。 。 图 7.16 打印 苹果 颜色 和 形状 属性 
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力 关键 技术 
在 PHP 面向 对 象 编程 方式 中 ， 可 以 使 用 extends 关键 字 继承 指定 的 父 类 ， 代 码 如 下 : 


class Parentl // 定 义 父 类 Parentl 
// 父 类 的 成 员 

i Child extends Parent] // 定 义 子 类 Child 
// 子 类 的 成 员 


} 
通过 上 述 继承 关系 ， 即 可 在 子 类 中 使 用 parent 关键 字 加 “::” 操 作 符 调用 父 类 的 公有 方法 或 属性 ,或 者 重 写 
非 final 关键 字 修饰 的 方法 。 


图 设计 过 程 
(1) 定义 水 果 类 Fruit， 在 该 类 中 定义 颜色 属性 Scolor 和 形状 属性 Sshape， 并 通过 构造 方法 对 这 两 个 属性 进 
行 初始 化 ， 然 后 定义 用 于 获得 这 两 个 属性 的 getColor0 方 法 和 getShape0 方 法 ， 代 码 如 下 : 


class Fruit // 定 义 水 果 类 
i 
private $color; /颜色 属性 
private $shape; /形状 属性 
public function ”construct ($color, $shape) // 构 造 方法 对 水 果 类 初始 化 
{ 
Sthis->color = $color; 
Sthis->shape = $shape; 
} 
public function getColor 0 /获得 水 果 颜 色 
{ 


return $this->color; 
} 
public function getShape 0) // 获 得 水 果 形状 
{ 


return $this->shape; 
} 
} 


(2) 定义 苹果 类 Apple， 使 该 类 继承 自 水 果 类 Fruit， 并 定义 苹果 类 的 构造 方法 ， 在 构造 方法 中 使 用 parent 
关键 字 调 用 父 类 构造 方法 对 父 类 进行 初始 化 ， 代 码 如 下 : 
class Apple extends Fruit /党 果 类 继承 水 果 类 
public function construct ($color. $shape) /构造 方法 对 类 进行 初始 化 
{ 


Parent::_ construct($color, $shape); 
} 
} 


(3) 建立 苹果 颜色 和 形状 录入 表单 。 用 户 在 表单 中 输入 苹果 的 颜色 和 形状 后 单 击 “ 提 交 ” 按 钮 ， 将 通过 如 


下 代码 打印 苹果 的 颜色 和 形状 属性 。 
ifisset($_POST['color]) && $_POST['color]!="){ // 判 断 是 否 已 经 提交 表单 
require Fruit.php'; // 包 含水 果 类 
$apple = new Apple($_ POST['color].$_POST[shape]): /对 水 果 类 进行 实例 化 
echo' ”<font color-"blue"> 我 看 见 的 苹果 是 : '.$apple->getColor0.,，'-S$apple->getShape0.' 的 <font>': /打印 苹果 属性 


了 

上 述 代码 首先 判断 用 户 是 否 已 经 提交 表单 ， 如 果 是 则 首先 使 用 require 语句 包含 苹果 类 ， 然 后 使 用 new 关键 
字 对 苹果 类 进行 实例 化 ， 最 后 使 用 苹果 类 实例 的 对 象 调用 父 类 中 的 getColor0 方 法 和 getShape( 方 法 ， 打 印 苹果 
的 属性 。 
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心 法 领悟 326: 使 用 final 关键 字 防止 类 被 继承 。 
本 实例 的 关键 技术 中 已 经 说 明 父 类 中 使 用 final 关键 字 所 修饰 的 方法 不 能 被 重 写 , 那么 如 何 使 一 个 类 不 能 被 


其 他 类 所 继承 呢 ? 同样 可 以 通过 final 关键 字 来 修饰 ， 代 码 如 下 : 
final class Fruit /使 用 final 关键 字 修饰 类 
{ 


} 
上 述 的 Fruit 类 被 final 关键 字 所 修饰 ， 这 样 该 类 就 不 能 被 其 他 类 所 继承 。 


实例 1 
实例 327 人 林寺， 机 机 机 
图 实例 说 明 
本 实例 主要 使 用 parent 关键 字 在 小 汽车 类 中 调用 汽车 类 的 行驶 方法 。 0 
运行 本 实例 ， 如 图 7.17 所 示 ， 分 别 在 页 面 中 打印 出 通过 汽车 类 调用 其 自 Ew 
身 的 行驶 方法 ， 以 及 其 子 类 小 汽车 类 调用 其 自身 的 行驶 方法 的 结果 。 图 7.17 打印 汽车 和 小 汽车 的 行驶 方法 
图 关键 技术 
在 PHP 5.0 面向 对 象 的 编程 方式 中 ， 使 用 parent 关键 字 加 操作 符 “::” 调 用 父 类 的 方法 ， 调 用 过 程 如 下 : 
class Parentl /定义 父 类 
public function funParentO{ /定义 父 类 的 funParent0 方 法 
。 } 
class Child extends Parentl // 定 义 子 类 
public function funChildO{ // 定 义 子 类 的 funChild0 方 法 
parent::funParent(); // 调 用 父 类 的 方法 


} 
} 
使 用 parent 关键 字 不 仅 可 以 调用 父 类 的 普通 方法 , 而 且 可 以 通过 调用 父 类 的 构造 方法 实现 对 父 类 的 初始 化 。 


看 设计 过 程 
(1) 定义 汽车 类 并 在 该 类 中 定义 汽车 的 行驶 方法 ， 代 码 如 下 : 
class Car // 定 义 汽车 类 
， public function run () /定义 行驶 方法 
retum ' 行 驶 ': 


} 


} 

(2) 定义 小 汽车 类 使 其 继承 自 汽车 类 ， 在 类 体内 定义 smallCarRun0 方 法 ， 并 在 该 方法 中 使 用 parent 关键 
字 调 用 汽车 类 的 run0 方 法 ， 代 码 如 下 : 

class SmallCar extends Car // 定 义 小 汽车 类 ， 使 之 继承 自 汽车 类 


{ 
public function smallCarRun | // 定 义 小 汽车 行驶 方法 


{ 
retum ' 小 汽车 可 以 '. parent:run0: 


了 
} 
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(3) 使 用 require 语句 包含 Car.php 文件 ， 分 别 对 汽车 类 Car 和 小 汽车 类 SmallCar 进行 实例 化 ， 然 后 分 别 
调用 这 两 个 类 的 行驶 方法 ， 代 码 如 下 : 


require 'Car.php'; // 包 含 汽 车 类 
S$car = new Car(); 1/ 对 汽车 类 进行 实例 化 
echo $car->run0 . ‘<br/>"; /调用 汽车 类 行驶 方法 
SsmallCar =new SmallCar(); /实例 小 汽车 类 
echo $smallCar->smallCarRun0; // 调 用 小 汽车 类 的 行驶 方法 
要 
图 秘笈 心 法 


心 法 领悟 327: 使 用 parent 关键 字 调 用 父 类 的 静态 成 员 。 
在 PHP 5.0 面向 对 象 编程 方式 中 ， 不 仅 可 以 使 用 parent 关键 字 调 用 父 类 的 普通 成 员 ， 而 且 可 以 使 用 parent 
关键 字 加 操作 符 “::” 调 用 父 类 的 静态 成 员 。 


i 
图 实例 说 明 

本 实例 主要 通过 在 苹果 类 中 重 写 其 父 类 水 果 类 的 getColor0 i 
方法 来 讲解 如 何 应 用 类 的 重 写 机 制 。 运 行 本 实例 ， 如 图 7.18 所 Eee 


示 ， 其 中 第 一 行为 通过 水 果 类 调用 其 自身 的 getColor0 方 法 的 输 。 
出 结果 ， 第 二 行为 苹果 类 调用 其 自身 的 getColor0 方 法 的 输出 结 。 图 718 村 号 水 困 类 中 的 getColor0 广 法 的 结果 
果 ， 并 且 该 方法 重 写 了 其 父 类 水 果 类 的 getColor0 方 法 。 


图 关键 技术 


子 类 不 仅 可 以 调用 父 类 的 方法 , 而且 可 以 对 指定 的 方法 进行 重 写 , 应 用 重 写 机 制 可 以 扩展 类 中 方法 的 功能 ， 
其 中 实现 对 类 中 方法 重 写 的 代码 示例 如 下 : 


class Parentl // 父 类 Parentl 

。 public function fun0{ // 父 类 的 fun0 方 法 
} 

二 Child extends Parentl // 子 类 Child 继承 自 Parentl 
public fanction funO{ /| 重 写 父 类 的 fun0 方 法 


3 


} 
对 上 述 代码 中 的 子 类 Child 进行 实例 化 ， 然 后 使 用 实例 化 后 的 对 象 调用 类 中 的 run0 方 法 ， 将 执行 子 类 重 写 
后 的 run0 方 法 的 功能 而 非 父 类 方法 的 功能 。 


力 设计 过 程 
(1) 定义 水 果 类 Fruit， 并 在 该 类 中 定义 getColor0 方 法 ， 然 后 定义 水 果 类 的 子 类 Apple， 使 该 类 继承 自 水 
果 类 Fruit， 在 蕴 果 类 Apple 中 重 写 其 父 关 的 getcolox0 方 法 ， 实 现 该 过 程 的 代码 如 下 : 
/定义 水 果 类 


class Fruit 
{ 
public function getColor 0 /获得 水 果 颜 色 


{ 
retum ' 不 同 的 水 果 颜色 不 同 ， 无 法 确定 : 
} 
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} 
class Apple extends Fruit // 莉 果 类 继承 水 果 类 


{ 
Private $color /定义 苹果 颜色 属性 
public fonction ”construct ($color) /构造 方法 对 类 进行 初始 化 


Sthis->color = $color: 


了 
public function getColor 0 /获得 水 果 颜 色 
retum "苹果 的 颜色 是 '. Sthis->color 


} 
(2) 包含 Fruitphp 文件 ， 然 后 使 用 new 关键 字 对 Fruit 类 进行 实例 化 ， 并 通过 实例 化 的 对 象 调 用 该 类 的 
getColor0 方 法 ， 最 后 对 Apple 类 进行 实例 化 ， 并 调用 Apple 类 中 的 getColor0 方 法 打印 苹果 的 颜色 ， 该 过 程 的 实 


现代 码 如 下 : 
require Fruit.php'; /包含 Fmitphp 文件 
Sfruit = new Fruit(); /对 水 果 类 进行 实例 化 
echo Sfruit->getColor().'<br/>"; /打印 水 果 类 的 获得 颜色 方法 
$apple = new Apple( 红 色 ); /对 苹果 类 进行 实例 化 
echo $apple->getColor(); /打印 苹果 类 的 获得 颜色 方法 
MS 
力 秘笈 心 法 


心 法 领悟 328: 通过 子 类 对 象 调 用 父 类 中 被 重 写 前 的 方法 。 

通过 子 类 被 实例 的 对 象 可 以 使 用 操作 符 “->” 直 接 调用 父 类 中 被 重 写 的 方法 ， 那 么 如 果 想 通过 子 类 对 象 调 
用 父 类 中 未 被 子 类 所 重 写 的 方法 该 如 何 实现 呢 ? 可 以 在 子 类 中 定义 一 个 私有 变量 ， 该 变量 用 于 保存 父 类 对 象 ， 
然后 在 子 类 构造 方法 中 对 父 类 进行 实例 化 ， 并 将 实例 化 后 的 对 象 赋 给 该 私有 变量 ， 同 时 在 类 体 中 定义 一 个 
getXxx() 方 法 , 该 方法 用 于 返回 父 类 被 实例 化 的 对 象 ,这样 在 类 体外 就 可 以 通过 子 类 被 实例 化 的 对 象 调用 getXxxO 
方法 ， i lb iii Li 实现 该 过 程 的 示例 代码 如 下 : 


class Parentl // 定 义 父 
public function fun 0 /定义 父 类 的 fun0 方 法 
{ 
retumn Parent’; 
; 
class Child extends Parentl // 定 义 子 类 Child 
Private $parent; /定义 私有 成 员 ， 用 于 保存 父 类 对 象 
public function constmuct 0 / 子 类 构造 方法 
Sthis->parent = new Parent10: /对 父 类 进行 初始 化 
} 
public function getParent () /返回 父 类 对 象 
{ 
return $this->parent: 
} 
public function fun 0 // 重 写 父 类 的 fun0 方 法 
return 'Child'; 
} 
Schild = new Child0: /对 child 类 进行 实例 化 
echo $child->getParentO->fun0): /以 链 状 方式 调用 父 类 未 被 重 写 的 fun0 方 法 


7.4 抽象 类 和 接口 
抽象 类 是 为 规范 面向 对 象 编程 提供 一 种 方式 ， 不 能 被 实例 化 ， 只 能 被 其 他 类 所 继承 。 接 口 是 为 了 实现 一 种 
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特定 功能 而 预 留 的 类 似 类 的 一 种 类 型 ， 只 允许 定义 常量 和 方法 ， 并 且 这 里 的 方法 没有 任何 功能 实现 。 本 节 将 通 
过 具体 实例 讲解 PHP 5.0 面向 对 象 编程 方式 中 抽象 类 和 接口 的 应 用 。 


宗 ' 合 
力 实例 说 明 

通过 本 实例 可 以 演示 抽象 类 不 能 被 实例 化 ， 只 能 被 继承 的 特点 。 本 实例 首先 定义 抽象 的 父 类 美食 类 ， 然 后 
定义 该 类 的 子 类 面包 类 ， 最 后 分 别 对 这 两 个 类 进行 实例 化 并 调用 获取 制作 原料 的 方法 。 运 行 本 实例 ， 将 在 页 面 
打印 如 图 7.19 所 示 的 错误 提示 ， 从 错误 提示 可 知 ， 抽 象 类 不 能 被 实例 化 。 


如 果 将 抽象 类 实例 的 代码 注释 掉 ， 再 次 运行 本 实例 ， 将 出 现 如 图 7.20 所 示 的 结果 ， 程 序 可 以 正常 运行 ， 说 
明 抽象 类 可 以 被 继承 。 


Fatal error: Connotinstantiste abstroct class Foodin 
DaAppSernmnMRIOTO16unierglg cn ine 15 | 证 醒 和 的 材料 是 ， 桓 粉 | 


图 7.19 实例 抽象 类 的 错误 提示 图 7.20 调用 抽象 类 子 类 的 结果 


力 关键 技术 


抽象 类 与 普通 类 的 区 别 在 于 ， 抽 象 类 不 能 被 实例 化 ， 即 不 能 用 来 创建 对 象 只 能 被 继承 。 抽 象 类 的 定义 方法 
是 在 class 前 加 关键 字 abstract， 代 码 如 下 : 


abstract class MyClass{ 
// 类 中 的 属性 和 方法 


} 

如 果 对 抽象 类 进行 实例 化 ， 将 在 页 面 打 印 如 图 7.19 所 示 的 错误 信息 。 
图 设计 过 程 

(1) 定义 抽象 美食 类 Food， 在 该 类 中 定义 $material 属性 ， 并 通过 构造 方法 对 该 属性 进行 初始 化 ， 然 后 定 
义 getMaterial0 方 法 返回 美食 的 京 制 材料 ， 代 码 如 下 : 


abstract class Food /人 业 食 类 
private $material; // 亮 制 材料 
public function __construct ($material) // 父 类 构造 方法 
S$this->material = $material; 
ns function getMaterial | /获得 美食 材料 方法 


Teturn $this->material: 


} 
(2) 定义 面包 类 Bread， 并 使 其 继承 自 美食 类 Food， 然 后 在 该 类 的 构造 方法 中 使 用 parent 关键 字 调 用 父 类 
的 构造 方法 实现 对 其 父 类 的 初始 化 ， 该 过 程 的 实现 代码 如 下 : 
class Bread extends Food /面包 类 继承 美食 类 
public function 。 construct (Smaterial) // 子 类 构造 方法 
{ 
parent::_construct($material): 


} 
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(3) 使 用 require 语句 在 index.php 中 包含 Food.php 文件 , 然后 使 用 new 关键 字 对 Bread 类 进行 初始 化 ,最 

后 通过 其 实例 化 的 对 象 调用 getMaterial0 方 法 打印 出 制作 面包 所 需 的 材料 ， 代 码 如 下 : 

require Food.php'; 

Smaterial = ' 面 粉 : 

1Sfood = new Food($material); 

llecho $food->getMaterial|.'<br/>"; 

Sbread = new Bread($material); 

echo ' 制 作 面包 的 材料 是 : "$bread->getMaterial0.<br/>'; 


国 秘笈 心 法 


心 法 领悟 329: PHP 面向 对 象 编程 方式 只 能 实现 单 继 承 。 
上 文 对 PHP 的 继承 进行 了 介绍 , 但 都 是 单一 继承 , 那么 PHP 能 否 实现 多 继承 呢 ? 可 以 通过 定义 如 下 类 的 相 


互 关系 进行 判断 。 
abstract class A{ /定义 抽象 类 A 
1 
abstract class B{ /定义 抽象 类 B 
} 
class C extends A, B{ /定义 类 C， 使 其 分 别 继承 自 类 A 和 类 BB 


} 
上 述 代码 中 ， 首 先 定义 抽象 类 A 和 抽象 类 B， 然 后 定义 类 C 使 其 同时 继续 类 A 和 类 B。 运 行 上 述 代码 ， 将 
在 页 面 打印 如 下 错误 信息 ， 说 明 PHP 目前 是 不 能 实现 多 继承 的 。 
Parse error: syntax error, unexpected ' expecting '{ in D:\AppServ\www\MR\ONO16\tphp on line 8 
et 
实现 中 级 | 
趣味 指数 : 请 博 良 | 


实例 330 


力 实例 说 明 


本 实例 主要 介绍 PHP 面向 对 象 编程 中 接口 的 定义 、 应 用 ， 以 及 类 如 何 实现 
多 个 接口 。 运 行 本 实例 ， 如 图 7.21 所 示 ， 首 先 在 表单 中 输入 学 生 的 学 号 和 学 生 
姓名 ， 然 后 单 击 “ 提 交 ” 按 钮 即 可 在 页 面 中 打印 出 学 生 信 息 。 


| | 关键 技术 图 7.21 打印 学 生 信息 


本 实例 的 关键 技术 是 如 何 定义 接口 ， 以 及 如 何 实现 一 个 或 多 个 接口 。 在 PHP 中 接口 使 用 关键 字 interface 声 
明 ， 在 类 体内 不 能 有 属性 定义 ， 只 能 有 方法 声明 ， 并 且 不 能 在 方法 中 定义 任何 功能 代码 ，PHP 中 接口 的 定义 方 
法 如 下 : 
interface name 
: public funetion fun10; 
private fanction fan2($param): 


} 
对 接口 定义 完成 后 ， 可 以 在 定义 类 时 使 用 关键 字 implements 实现 一 个 或 多 个 接口 ， 所 实现 的 多 个 接口 名 称 
之 间 使 用 逗号 分 隔 ， 例 如 : 


class MyClass implements interfacel, interface2. interface3 


请 次 入 学 生 编号 [la5iE 
请 大 和 学 名 汐 四 到 
| 


当前 学 生 的 学 寻 是 ，0312315 姓名 是 :小 刘 


/需要 实现 各 个 接口 中 所 声明 的 方法 


} 
综 上 可 知 ， 实 现 接口 的 类 中 至 少 应 包括 所 实现 接口 中 声明 的 方法 。 
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图 设计 过 程 
(1) 定义 学 生 ID 接口 ， 在 接口 中 声明 用 于 设置 学 生 ID 的 setId0 方 法 和 获得 学 生 ID 的 getId0 方 法 ， 代 码 
如 下 : 
interface Property Id /编号 接口 
1 public function setId ($id); /方法 声明 


public function getId 0: 


} 
(2) 定义 学 生 名 称 接口 Property_Name， 并 在 接口 中 声明 设置 学 生 姓 名 的 setName0 方 法 和 获得 学 生 姓名 的 
getName() 方 法 ， 实 现代 码 如 下 : 
interface Property_ Name // 名 称 接口 
: public function setName ($name); /方法 声明 
public function getName 0; 


} 
(3) 定义 学 生 类 Student， 使 其 同时 实现 Property_Id 接口 和 Property_Name 接口 ， 并 实现 类 中 所 声明 方法 


的 定义 ， 代 码 如 下 : 
class Student implements Property_Id, Property_Name // 定 义学 生 类 ， 使 其 同时 实现 Property_Id 和 Property_Name 两 个 接口 
{ 
private $id; /| 编号 属性 
Private $name; // 名 称 属性 
public function setId ($id) // 实 现 接口 中 的 各 个 方法 
Sthis->id = $id; 


ge function getId () 

, retum S$this->id; 

ee function setName ($name) 
Sthis->name = $name; 

pote function getName 0 


Tetumn $this->name: 


} 


} 
(4) 建立 学 生 属 性 信息 录入 表单 ， 当 单 击 表单 中 的 “提交 ”按钮 后 ， 将 在 页 面 中 打印 出 所 录入 的 学 生 编 号 
和 学 生 名 称 ， 代 码 如 下 : 


iflisset($_POST['id]) && $_POST['id]!="){ // 判 断 是 否 提交 了 表单 
require 'Student.php'; /包含 学 生 类 
$student = new Student0: /对 学 生 类 进行 实例 化 
S$student->setId($_POST['id]): /i/ 设 定 学 生 了 DD 
$student->setName($_POST['name']): // 设 定 学 生 名 称 
echo '<font color="green"> 当 前 学 生 的 学 号 是 :'.$student->getId0.， 姓名 是 : "$student->getName0.'</font>'; /打印 学 生 信息 


} 

上 述 代码 中 ， 首 先 判断 是 否 已 经 提交 了 表单 ， 如 果 是 ， 则 首先 使 用 require 语句 包含 Student.php 文件 ， 然 后 
使 用 new 关键 字 对 学 生 类 Student 进行 实例 化 , 并 调用 实例 化 后 对 象 的 setXxx0 方 法 分 别 为 学 生 编 号 和 学 生 姓名 
赋 初 值 ， 最 后 分 别 调用 类 中 的 getXxx0 方 法 打印 学 生 信 息 。 


图 秘笈 心 ; 
心 法 领悟 330: require 语句 与 include 语句 的 区 别 。 
加 ”只 要 程序 运行 就 会 将 require 语句 所 包含 的 文件 包含 进来 ， 而 include 语句 则 是 在 执行 到 该 语句 时 包含 


指定 的 文件 。 
回 ” 如 果 包 含 的 语句 不 存在 ，require 语句 将 给 出 错误 提示 ， 而 include 语句 给 出 警告 。 
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7.5 类 的 多 态 


多 态 是 面向 编程 方式 的 重要 特点 之 一 ， 通 过 多 态 可 以 为 类 提供 功能 上 的 多 种 实现 ，PHP 中 可 以 通过 继承 或 
接口 来 实现 类 的 多 态 。 


实例 331 
力 实例 说 明 
本 实例 主要 通过 继承 表现 类 的 多 态 。 在 制作 本 实例 时 ， 首 先 定义 动物 类 ee 
Animal， 然 后 分 别 定义 企 下 类 Penguin 和 昆虫 类 Insect， 并 在 这 两 个 子 类 中 Se 
分 别 重 写 动 物 类 的 行走 方法 , 最 后 通过 这 两 个 子 类 实例 化 的 对 象 调用 其 自身 
的 行走 方法 ， 将 在 页 面 打印 如 图 7.22 所 示 的 内 容 。 图 722 通过 继承 实现 类 的 多 态 
图 关键 技术 


本 实例 的 关键 是 如 何 通过 继承 来 实现 类 的 多 态 。 在 PHP 面向 对 象 编程 中 ， 可 以 首先 定义 一 个 抽象 的 父 类 
然后 再 定义 多 个 子 类 来 继承 该 父 类 ， 在 子 类 中 可 以 通过 方法 重 载 的 方式 重 写 父 类 中 的 功能 ， 这 样 就 实现 了 类 的 


多 态 ， 代 码 如 下 : 
abstract class Parent // 定 义 抽象 的 父 类 Parent 
public function fan | /定义 父 类 的 fun0 方 法 
: retum ' 父 类 fun0 方 法 的 实现 '; 
过 Childl extends Parent // 定 义 子 类 Child1， 使 其 继承 Parent 
。 public function fan 0 /在 childl 中 重 写 Parent 类 中 的 fun0 方 法 


retum 'Child1 中 fun0 方 法 的 实现 '; 
} 


} 
class Child2 extends Parent // 定 义 子 类 Child2， 使 其 继承 Parent 


public function fun | /在 Child2 中 重 写 Parent 类 中 的 fun0 方 法 
retum 'Child2 中 fun0 方 法 的 实现 ': 
: } 
图 设计 过 程 


(1) 定义 抽象 的 动物 类 Animal， 并 在 该 类 中 定义 行走 的 方法 walk0， 然 后 定义 企鹅 类 Penguin 和 昆虫 类 
Insect， 使 二 者 分 别 继承 类 Animal， 并 在 这 两 个 类 中 重 写 Animal 类 中 的 walk0 方 法 ， 代 码 如 下 


abstract class Animal // 定 义 动物 类 
4 
public function walk 0 /定义 动物 类 中 的 行走 方法 
{ 
retum ' 动 物 能 行走 


} 
} 
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class Penguin extends Animal // 定 义 企鹅 类 ， 并 使 其 继承 自动 物 类 
i, public function walk 0 // 重 写 父 类 中 的 walk0 方 法 

: retum ' 企 的 可 以 直立 行走 '; 
J Insect extends Animal // 定 义 昆虫 类 ， 并 使 其 继承 自动 物 类 
\ public function walk (| // 重 写 父 类 中 的 walk0 方 法 

| retum "昆虫 可 以 疏 行 : 


1 
} 


(2) 使 用 require 语句 包含 Animal.php 文件 ， 然 后 分 别 对 企鹅 类 和 昆虫 类 进行 实例 化 ， 并 分 别 调用 这 两 个 
类 中 的 walk0 方 法 ， 代 码 如 下 : 


require 'Animal.php'; /包含 Animal.php 文件 
Spenguin = new Penguin(); // 对 企鹅 类 进行 实例 化 
echo $penguin->walkO; // 调 用 企鹅 类 的 walk0 方 法 
echo ‘<br/>'; 

Sinsect = new Insect(); // 对 昆虫 类 进行 实例 化 
echo $insect->walk(); // 调 用 昆虫 类 的 walk0 方 法 


通过 上 述 实 例 的 运行 结果 可 知 ， 企 鹅 类 和 昆虫 类 虽然 都 重 写 了 父 类 的 wakk0 方 法 ， 但 在 页 面 中 的 打印 结果 
却 不 同 ， 这 就 是 通过 继承 实现 类 多 态 的 体现 。 


秘 敌 心 ; 
心 法 领悟 331: 使 用 abstract 关键 字 防 止 类 被 实例 化 。 
在 PHP 面向 对 象 编程 中 ,如 果 所 定义 的 类 只 能 被 其 他 类 继承 ,而 自身 并 不 需要 进行 实例 化 ,可 以 使 用 abstract 


关键 字 将 该 类 声明 为 抽象 类 。 
例如 定义 抽象 类 A， 代 码 如 下 : 
i class A{ /定义 抽象 类 人 
二 AO; // 对 类 A 进行 实例 化 


如 果 对 类 A 使 用 new 关键 字 进 行 实例 化 ， 将 在 页 面 中 打印 如 下 错误 信息 ， 从 而 说 明 抽 象 类 是 不 能 被 实例 
化 的 


Fatal error: Cannot instantiate abstract class A in D:\AppServ\Wwww\MR\O7N\018\t.php on line 5 


实例 332 

力 实例 说 明 
本 实例 主要 介绍 如 何 通 过 接口 来 表现 类 的 多 态 性 。 制作 本 实例 时 ， 首 先 二 

定义 动物 接口 Animal, 然后 分 别 定义 企 丽 类 和 昆虫 类 来 实现 这 个 接口 并 实 

现 接口 中 所 声明 的 walk0 方 法 ， 运 行 本 实例 ， 效 果 如 图 7.23 所 示 。 

图 关键 技术 图 7.23 通过 接口 实现 类 的 多 态 
在 继承 中 通过 方法 重 写 方式 可 以 体现 类 的 多 态 性 ， 通 过 接口 的 方式 同样 可 以 体现 类 的 多 态 性 ， 代 码 如 下 : 
interface A /定义 接口 A 
public function fun |; // 声 明 接 口中 的 fun0 方 法 
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} 
class Classl implements A /定义 类 Class1， 使 其 实现 接口 A 


public function fun 0 // 实 现 接 口 A 中 的 fun0 方 法 


retum ' 在 类 Classl 中 实现 接口 A 中 的 fun0 方 法 ': 


} 
class Class2 implements A 
{ 
public function fun 0 /实现 接口 A 中 的 fun0 方 法 


retum ' 在 类 Class2 中 实现 接口 A 中 的 fun0 方 法 ': 
} 


} 

上 述 代 码 中 ， 定 义 接口 A， 并 在 接口 中 声明 fun0 方 法 ， 然 后 分 别 定 义 类 Classl 和 类 Class2， 使 这 两 个 类 都 
实现 接口 A， 并 实现 接口 A 中 的 fun0 方 法 。 从 示例 代码 中 可 知 ， 类 Classl 和 类 Class2 虽然 都 实现 了 接口 A 中 
所 声明 的 fun0 方 法 ， 但 这 两 个 方法 实现 的 功能 却 不 同 ， 从 而 体现 类 的 多 态 性 。 


图 设计 过 程 
(1) 定义 动物 类 接口 Animal， 并 在 该 接口 中 声明 walk0 方 法 ， 然 后 定义 企鹅 类 Penguin 和 昆虫 类 Insect， 
使 这 两 个 类 分 别 实现 Animal 接口 ， 代 码 如 下 : 


interface Animal // 定 义 动物 接口 
public function walk 0: // 声 明 行走 的 方法 

2 Penguin implements Animal // 定 义 企鹅 类 ， 并 使 其 实现 动物 接口 
public function walk 0 // 重 写 父 类 中 的 walk0 方 法 


retur "企鹅 可 以 直立 行走 '; 


} 
class Insect implements Animal // 定 义 昆虫 类 ， 并 使 其 实现 动物 接口 


public function walk 0 // 重 写 父 类 中 的 walk0 方 法 
return "昆虫 可 以 疏 行 : 
} 
} 
(2) 分 别 对 企鹅 类 和 昆虫 类 进行 实例 化 ， 然 后 使 用 实例 化 的 对 象 调用 类 中 的 walk0 方 法 ， 代 码 如 下 : 


require 'Animal.php'; // 包 含 Animalphp 文件 

Spenguin = new Penguin(): // 对 企鹅 类 进行 实例 化 

echo $penguin->walk0: 1/ 调用 企 护 类 的 walk0 方 法 

echo ‘<br/>'; 

Sinsect = new Insect(|; // 对 昆虫 类 进行 实例 化 
echo Sinsect->walk(); /1/ 调 用 昆虫 类 的 walk0 方 法 
> We 

图 秘笈 心 法 


心 法 领悟 332: 抽象 类 和 接口 的 区 别 。 

回 ”在 定义 上 ， 在 抽象 类 中 可 以 对 方法 所 实现 的 功能 进行 具体 定义 ， 而 在 接口 中 只 能 对 方法 进行 声明 ， 不 
能 具体 实现 方法 的 功能 。 

回 “ 在 用 法 上 ， 继 承 抽象 类 的 子 类 可 以 重 写 父 类 的 方法 ， 或 通过 实例 后 的 对 象 直接 调用 父 类 中 的 方法 ， 而 
实现 接口 的 类 中 ， 必 须 包含 所 实现 接口 的 所 有 方法 。 
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7.6 常用 关键 字 


在 PHP 面向 对 象 编程 中 ， 有 些 关键 字 是 需要 掌握 的 ， 如 final、static、clone、instanceof 等 ， 本 节 将 通过 具 
体 实例 讲解 这 些 关 键 字 的 使 用 方法 。 


genonsanan 


力 实例 说 明 


本 实例 主要 讲解 final 关键 字 的 用 法 。 首 先 定义 水 果 类 Fruit，, 然后 定义 final 型 的 苹果 类 Apple, 使 之 继承 自 
水 果 类 ， 通 过 Apple 类 即 可 实现 对 苹果 属性 的 设置 。 运 行 本 实例 ， 如 图 7.24 所 示 ， 首 先 在 文本 框 中 输入 苹果 的 
颜色 和 形状 属性 ， 然 后 单 击 “ 提 交 ” 按 钮 ， 即 可 在 页 面 中 打印 出 苹果 的 属性 信息 。 如 果 再 定义 一 个 类 ， 并 使 之 
继承 final 型 的 Apple 类 ， 则 会 在 页 面 中 打印 出 如 图 7.25 所 示 的 错误 提示 信息 。 


omer: Clace Toot may not 


inherit fiom final class (Appl in 


App Servwww MR TZ0 
NFruitplp on ine 30 
图 7.24 打印 苹果 的 属性 图 7.25 ”继承 final 型 水 果 类 的 错误 提示 
图 关键 技术 
通过 本 实例 的 运行 结果 可 知 ,使 用 final 关键 字 修 饰 的 类 只 能 被 实例 化 不 能 被 继承 ,如果 继承 了 final 型 的 类 ， 
将 在 页 面 中 打印 如 下 错误 提示 : 
Fatal error: Class Test may not inherit from final class (Apple) in D:\AppServ\wwwiMR\07\020\Fmit.php on line 30 
图 设计 过 程 


(1) 定义 水 果 类 Fruit， 在 该 类 中 定义 水 果 的 颜色 属性 Scolor， 并 通过 构造 方法 对 颜色 属性 进行 初始 化 ， 然 
后 定义 获得 颜色 的 getColor0 方 法 ， 代 码 如 下 : 


class Fruit // 定 义 水 果 类 
L private Seolor /定义 颜色 属性 
public function __constmct ($color) /通过 构造 方法 对 颜色 属性 进行 初始 化 
$this->color = $color: 
as function getColor | /获得 水 果 颜 色 的 方法 


Tetum $this->color; 
} 


} 
(2) 定义 final 型 的 苹果 类 Apple， 并 使 其 继承 水 果 类 Fruit， 在 水 果 类 中 定义 苹果 的 形状 属性 $shape， 通 过 


构造 方法 对 苹果 类 进行 初始 化 ， 最 后 定义 getShape0 方 法 返回 水 果 的 形状 ， 代 码 如 下 : 
final class Apple extends Fruit // 定 义 final 型 的 苹果 类 ， 使 之 继承 水 果 类 


454 


第 7 章 面向 对 象 


private $shape; /定义 形状 属性 
public funetion ”constmuct ($color, $shape) // 构 造 函 数 
{ 
parent::_construct($color); // 调 用 父 类 构造 方法 
Sthis->shape = $shape: // 对 形状 属性 进行 初始 化 
和 
public function getShape 0 /获得 苹果 的 形状 方法 
return $this->shape; 
并 
class Test extends Apple { // 定 义 一 个 Test 测试 类 ， 使 之 继承 final 型 的 Apple 类 


} 
#/ 


上 述 代 码 中 ， 以 多 行 注释 的 部 分 用 于 测试 被 关键 字 final 修饰 的 类 是 否 可 以 被 继承 。 
(3) 建立 苹果 属性 录入 表单 ， 当 用 户 单 击 表单 中 的 “提交 ”按钮 后 ， 将 通过 如 下 代码 打印 出 苹果 的 属性 : 
ifisset($_POST[color]) && $_POST['color]!="){ 
require Fruit.php'; 
$apple =new Apple($_POST['color], $_POST['shape]); 
echo '<font color="red"> 蔷 果 是 '.$apple->getColor().$apple->getShape0. 的 </font>'; 
} 
上 述 代码 中 ， 首 先 判 断 用 户 是 否 已 经 提交 了 表单 ， 如 果 是 ， 则 首先 使 用 require 语句 包含 Fruitphp 文件 ， 然 
后 对 苹果 类 进行 实例 化 ， 最 后 分 别 通过 getColor0 方 法 和 getShape0 方 法 打印 出 苹果 的 属性 。 


图 秘笈 心 ; 
心 法 领悟 333: 使 用 issetO 函 数 判断 用 户 是 否 提交 了 表单 。 
在 实际 项 目 开 发 中 ， 经 常 需要 将 表单 提交 到 当前 页 面 进行 处 理 ， 而 处 理 表 单 所 提交 内 容 的 代码 需要 在 表 


单 提交 后 执行 ， 那 么 如 何 判断 用 户 已 经 提交 了 表单 呢 ? 在 PHP 中 可 以 通过 isset0 函 数 实现 ， 该 函数 的 语法 格 
式 如 下 : 


boolisset (mixed var [, mixed var [. .了 ]) 
该 函数 的 参数 为 一 个 变量 列表 ， 如 果 所 指定 的 全 部 变量 都 已 经 设置 值 则 返回 TRUE， 反 之 有 一 个 没有 被 设 
置 值 则 返回 FALSE， 例 如 本 实例 中 通过 如 下 代码 判断 是 否 已 经 提交 了 表单 。 


iflisset($_POST['color]) && $_POST['color]!="){ // 判 断 用 户 是 否 已 经 提交 了 表单 
/提交 表单 后 的 处 理 代码 
} 
> | 
实例 334 义 类 的 静态 成 员 中 级 | 
则 起 味 指数 : 评 相 | 


力 实例 说 明 


本 实例 主要 讲解 PHP 面向 对 象 编程 方式 中 static 关键 字 的 用 法 ， 运 行 效果 如 图 7.26 所 示 。 首 先 在 图 7.26 的 
文本 框 中 输入 要 计算 的 数字 ， 同 时 在 计算 类 型 下 拉 列 表 框 中 选择 计算 类 型 ， 然 后 单 击 “ 求 值 ”按钮 ， 即 可 在 页 面 
中 打印 出 计算 结果 。 这 里 要 注意 ， 在 进行 除法 运算 时 ， 如 果 除数 为 0， 则 应 该 给 出 错误 提示 ， 如 图 7.27 所 示 。 


图 7.26 数值 计算 器 图 7.27 除数 为 0 时 的 提示 信息 
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图 关键 技术 


在 PHP 面向 对 象 编程 方式 中 ,使 用 static 关键 字 修饰 的 属性 称 为 静态 属性 ， 使 用 static 关键 字 修 饰 的 方法 称 
为 静态 方法 ， 通 过 类 实例 的 对 象 可 以 调用 类 中 的 公有 方法 ， 而 静态 成 员 的 特点 是 在 不 对 类 进行 实例 化 的 前 提 下 ， 
直接 通过 类 名 即 可 对 其 进行 调用 ， 其 调用 格式 如 下 : 
类 名 :: 公 有 静态 成 员 
图 设计 过 程 
(1) 定义 数值 计算 类 Math， 并 在 Math 类 中 定义 用 于 进行 加 、 减 、 乘 、 除 运算 的 静态 方法 ， 在 进行 求 除 运 
算 中 通过 try/cateh 语句 进行 除数 为 0 时 的 异常 处 理 ， 实 现 该 过 程 的 代码 如 下 : 


class Math // 定 义 数值 计算 类 
{ 
public static function add (Snuml, Snum2) // 相 加 的 方法 
{ 
returm $numl + $num2; 
了 
public static function sub (Snuml, $num2) // 相 减 的 方法 
{ 
retum Snuml - $num2; 
} 
public static function multi (Snuml, $num2) // 相 乘 的 方法 
retumn Snuml + $num2; 
} 
public static function div (Snuml, Snum2) // 相 除 的 方法 
{ 
ty{ 
让 (Soum2 一 0){ /如 果 除 数 为 0， 则 抛 出 异常 
throw new Exception( 除数 不 能 为 07; 
}else{ 


return $numl / $num2; 


} catch (Exception $e) { 
retum $e->getMessage(); // 如 果 除 数 为 0， 则 给 出 错误 提示 
} 
1 
} 


(2) 定义 数值 录入 表单 ， 当 在 表单 中 录入 数字 并 单 击 表单 的 “ 求 值 ”按钮 后 ， 将 通过 如 下 代码 计算 出 表单 


中 所 定义 的 算数 运算 的 结果 。 
让 (isset($_POST[muml]) && trim($_ POST[mumlD]) (=") { / 潮 断 是 否 提交 了 表单 
require "Math.php'; // 包 含 Mathphp 文件 
$numl =$_ POST[muml1]: /获得 提交 的 数字 


Snum2 = $_POST[mum21]; 
switch ($_POST['type']) { 
case +t’: // 进 行 加 运算 
Sresult = Math::add(Snuml, $num?); 
break: 


case ~': // 进 行 减 运 算 
Sresult = Math::sub(Snuml. Snum2): 
break: 
case 中 // 进 行 乘 运算 
Sresult = Math::multi($numl. Snum2): 
break: 
case // 进 行 除 运算 
Sresult = Math::div($numl, Saum2): 
break: 
} 
echo ' 结 果 : '. $result; /打印 计算 结果 
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上 述 代码 中 ， 首 先 判断 表单 是 否 已 经 提交 ， 如 果 是 ， 则 使 用 switch 语句 判断 要 进行 计算 的 类 型 ， 然 后 通过 
Math 类 直接 调用 其 中 的 静态 方法 进行 计算 。 


心 法 领悟 334; 直接 通过 类 名 调用 类 中 的 静态 方法 时 不 调用 构造 方法 和 析 构 方法 。 
如 果 直接 通过 类 名 调用 类 中 的 静态 方法 ， 而 不 通过 new 关键 字 对 类 进行 实例 化 ， 是 否 也 会 执行 类 中 的 构造 


方法 和 析 构 方法 呢 ? 下 面 定 义 如 下 代码 ， 在 代码 中 定义 类 Test， 然 后 分 别 在 类 中 定义 构造 方法 、 析 构 方法 和 静 
态 方法 fhtn0， 最 后 使 用 类 名 直接 调用 静态 方法 fun(。 
class Test /定义 Test 类 
public function ”constmuct () /构造 方法 
echo ' 执 行 构造 方法 <br/>'; 
LS public function fun 0 /| 静态 方法 
echo ' 执 行 静态 方法 ': 
Lt function _ destrmct 0 // 析 构 方法 
; echo ' 执 行 析 构 方法 '; 
} 
和 /通过 类 名 调用 类 中 的 静态 方法 
运行 上 述 代 码 后 ， 将 在 页 面 中 打印 “执行 静态 方法 ”， 从 运行 结果 可 以 得 知 ， 如 果 通 过 类 名 调用 类 中 的 静 
态 方法 ， 将 不 调用 构造 方法 和 析 构 方法 。 


趣味 指数 : 依依 傅 


实例 335 


力 实例 说 明 

本 实例 主要 讲解 PHP 5.0 面向 对 象 编程 中 clone 关键 字 的 使 用 方法 ， 运 行 本 实例 ， 分 别 如 图 7.28 和 图 7.29 
所 示 ， 其 中 图 7.28 中 的 输出 结果 是 使 用 clone 关键 字 克 隆 对 象 后 ， 分 别 用 原来 的 对 象 和 克隆 的 对 象 对 类 中 方法 
进行 重新 赋值 并 调用 的 结果 ， 而 图 7.29 为 使 用 等 号 赋值 的 方式 产生 一 个 新 对 象 后 ， 再 分 别 使 用 新 旧 对 象 实现 对 
类 中 的 方法 进行 调用 的 结果 。 


羊 的 黄色 是 白色 羊 的 新 他 是 白色 
Ee 
图 7.28 使 用 clone 关键 字 传 递 对 象 图 7.29 使 用 等 号 传递 对 象 


图 关键 技术 


在 PHP 5.0 以 后 的 版 本 中 ， 使 用 clone 关键 字 实 现 对 对 象 的 克隆 ， 该 关键 字 的 语法 格式 如 下 : 


Sobj_new = clone $obj_old: 
初学 者 可 能 会 问 , 直接 用 等 号 就 可 以 将 当前 对 象 赋 给 一 个 其 他 对 象 , 为 什么 还 要 用 clone 关键 字 ? 这 主要 是 
因为 在 PHP 5.0 中 ， 对 象 被 存储 于 独立 的 结构 Object Store 中 ， 而 不 像 其 他 一 般 变量 存储 于 Zval 中 。 在 Zval 中 
仅 存储 对 象 地 址 的 引用 ， 当 赋值 一 个 变量 或 者 将 一 个 变量 传递 给 一 个 函数 时 ， 就 不 再 复制 数据 了 ， 所 以 对 新 变 
量 的 更 改 不 会 影响 原 变量 的 内 容 ， 而 采用 Object Store 存储 对 象 时 ， 使 用 等 号 产生 一 个 新 对 象 后 ， 对 新 对 象 的 更 
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改 会 导致 原 对 象 的 更 改 ， 而 使 用 clone 关键 字 克 隆 对 象 ， 可 避免 这 一 问题 。 
[ED 说 明 : 使 用 clone 关键 字 克 隆 一 个 对 象 ， 就 好 比 克隆 一 个 人 ， 打 一 下 新 克隆 出 的 人 ， 被 克隆 的 人 并 不 会 感 
到 疼痛 ， 其 中 的 道理 是 一 样 的 。 
图 设计 过 程 
(1) 建立 羊 类 Sheep， 在 该 类 中 定义 羊 的 颜色 属性 $color， 同 时 定义 用 来 设置 颜色 的 setColor0 方 法 和 获得 
颜色 的 getColor0 方 法 ， 代 码 如 下 : 


class Sheep 
{ 
private $color; /颜色 属性 
public function setColor ($color) /设置 颜色 的 方法 


$this->color = $color: 
世 
public function getColor 0) // 获 得 颜色 的 方法 


retum ' 羊 的 颜色 是 ' . $this->color; 
} 


} 
(2) 对 Sheep 类 进行 实例 化 ， 然 后 分 别 用 等 号 赋值 和 用 clone 关键 字 测 试 对 对 象 进行 更 改 的 影响 结果 ， 代 


码 如 下 : 
require 'Sheep.php'; // 包 含 Sheep.php 文件 
S$sheep = new Sheep(); // 对 Sheep 类 进行 实例 化 
诬 
$sheep->setColor( 白 色 '); // 设 置 羊 的 颜色 
echo $sheep->getColor(); /打印 羊 的 颜色 
S$sheepl = $sheep: // 将 $sheep 对 象 赋值 给 新 对 象 Ssheep1l 
echo ‘<br/>; 
S$sheep1->setColor(' 灰 色 ); // 通 过 新 对 象 Ssheep1 调用 设置 颜色 的 方法 
echo $sheep->getColor();: 1/ 打印 羊 的 颜色 
4 
$sheep->setColor( 白 色 '); /设置 羊 的 颜色 
echo $sheep->getColor(); /打印 羊 的 颜色 
S$sheepl = clone $sheep; // 克 隆 $sheep 对 象 ， 产 生 一 个 新 的 $sheep1 对 象 
echo ‘<br/>'; 
$sheep1->setColor( 灰 色 ); // 通 过 新 克隆 的 $sheep1 对 象 调用 Sheep 类 中 的 setColor0 方 法 
echo $sheep->getColor(): /打印 羊 的 颜色 
图 秘笈 心 法 


心 法 领悟 335: 克隆 对 象 的 比较 方法 。 
在 PHP 中 可 以 使 用 “一 ”和 “= 一 ”操作 符 实现 对 象 的 比较 ， 为 了 明确 这 两 种 操作 符 的 差别 ， 首 先 看 下 面 


的 例子 。 
class Test /定义 Test 类 
// 类 体 
} 
S$test = new Test0: // 对 Test 类 进 实例 化 
S$test] = clone S$test; // 克 隆 一 个 新 的 $testl 对 象 
echo intval(($test 一 S$test1)) . <br/>" . intval(($test 一 一 S$test1)): // 打 印 比 较 结果 


运行 上 述 代 码 ， 将 在 页 面 中 打印 1 和 0。 原 因 就 是 在 对 象 比较 时 ，“ 一 ”比较 两 个 对 象 的 内 容 ， 而 “= 一 ” 
则 比较 两 个 对 象 的 句柄 ， 所 以 “Stest=-StestL ”比较 的 是 两 个 对 象 的 内 容 ， 返 回 结果 应 该 为 TRUE， 而 
“Stest 一 -Stestl ” 则 比较 两 个 对 象 的 句柄 ， 即 引用 地 址 ， 所 以 返回 FALSE。 
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实例 336 趣味 指数 : 相生 让 
力 实例 说 明 
本 实例 主要 讲解 PHP 面向 对 象 编程 中 ，instanceof 关键 字 的 使 用 rT 
方法 。 运 行 本 实例 ， 将 在 页 面 中 打印 出 如 图 7.30 所 示 的 结果 。 本 实 本 :外 色 


例 主要 定义 了 苹果 类 和 桔子 类 , 然后 分 别 对 这 两 个 类 进行 实例 化 , 同 
时 定义 一 个 根据 传递 的 对 象 自动 识别 对 象 所 属 类 的 方法 。 


图 关键 技术 


instanceof 关键 字 用 于 检测 某 实 例 是 否 属于 某 一 个 类 的 类 型 ， 如 果 是 ， 则 返回 TRUE， 反 之 返回 FALSE， 该 


关键 字 的 使 用 格式 如 下 : 
对 象 名 instanceof 类 名 


图 设计 过 程 
(1) 定义 苹果 类 Apple 和 桔子 类 Orange， 然 后 分 别 在 这 两 个 类 中 定义 获得 颜色 的 方法 getColor0， 代 码 如 下 : 
class Apple /定义 苹果 类 
， public function getColor | /获得 苹果 颜色 的 方法 


图 7.30 根据 不 同 的 对 象 调用 类 中 的 方法 


returm ' 红 色 '; 
} 
class Orange /定义 桔子 类 
上 public function getColor 0 /获得 桔子 颜色 的 方法 
retum ' 橙 色 '; 


} 
} 


(2) 使 用 require 语句 包含 Fruit.php 文件 ， 然 后 定义 根据 对 象 打印 水 果 颜 色 的 方法 ， 最 后 使 用 new 关键 字 
分 别 对 Apple 类 和 Orange 类 进行 实例 化 ， 并 使 用 getColor0 方 法 打印 出 相应 水 果 的 颜色 ， 代 码 如 下 : 


require Fruit.php'; // 包 含水 果 类 
function getColor ($0bj) /定义 根据 对 象 类 型 获得 相应 水 果 颜 色 的 方法 
证 (Sobj 本 于 1/ 判断 是 否 为 苹果 实例 的 对 象 
S$str = 苹果 是 : 
} elseif (Sobj instanceof Oo) { /判断 是 否 为 桔子 实例 的 对 象 
$str = ' 桔 子 是 : '; 
上 
return $str . Sobj->getColor0: /打印 结果 
} 
S$apple = new Apple0): /对 苹果 类 进行 实例 化 
Sorange = new Orange(); // 对 桔子 类 进行 实例 化 
echo getColor($apple) . '<br/>"; /打印 苹果 颜色 
echo getColor($orange); /打印 桔子 颜色 
图 秘笈 心 法 


心 法 领悟 336: 使 用 is_a0 函 数 判断 指定 的 对 象 是 否 属于 某 类 或 其 子 类 的 对 象 。 
从 本 实例 可 知 ， 使 用 instanceof 关键 字 可 以 检测 指定 的 对 象 是 否 属于 某 一 个 类 的 类 型 ， 而 PHP 中 又 提供 了 
is_a0 函 数 ， 该 函数 用 于 判断 指定 的 对 象 是 否 属于 某 类 或 其 子 类 的 对 象 ， 其 语法 格式 如 下 : 


PHP 开发 实例 大 全 (基础 卷 ) 


bool is_a ( object object, string class_name ) 
如 果 对 象 object 是 class_name 所 代表 类 或 父 类 的 对 象 则 返回 TRUE， 否 则 返回 FALSE。 
7.7 魔术 方法 


PHP 5.0 中 ， 主 要 提供 了 _ set0、_sget0、__isset0、_unset0、_clone0、_ toString0 和 _ autoload0 等 魔术 
方法 ， 本 节 将 通过 具体 实例 讲解 PHP 中 魔术 方法 的 含义 和 具体 使 用 方法 。 


Ey 


力 实例 说 明 
本 实例 主要 讲解 如 何 使 用 PHP 中 的 _ setO 方 法 存 取 类 中 未 声明 的 属性 。 运 行 本 实例 ， 如 图 7.31 所 示 ， 在 页 
面 中 以 表格 的 形式 列 出 各 本 图 书 的 详细 信息 ， 其 中 图 书 的 “备注 ”属性 使 用 _set0 方 法 赋值 。 


APHP 从 基础 天》 60 4 张 、 4 语 、 小 王 加 备注 
CE 30 4 活性 四 和 和 
APHE 和 全 "*》 m0 4 溯 、 小 35 EE 
LE) 7 本、 小 刘 四 EE 


图 7.31 图 书信 息 列表 


力 关键 技术 


魔术 方法 _set0 的 作用 是 存 取 类 中 未 声明 的 属性 ， 该 方法 必须 接收 两 个 参数 ， 分 别 用 来 表示 类 中 未 声明 的 


属性 名 和 属性 值 ，_set0 方 法 的 语法 格式 如 下 : 
fanction set(Sname, $value) 


// 可 以 使 用 $name 和 $value 在 方法 中 存 取 类 中 未 定义 的 属性 名 和 数值 

上 述 _set0 方 法 中 的 参数 $name 表示 类 中 未 声明 属性 的 名 称 ，S$value 表示 类 中 未 声明 属性 的 值 。 
图 设计 过 程 

(1) 定义 图 书 类 Book, 在 类 中 定义 图 书 的 名 称 、 页 码 、 作 者 和 价格 等 属性 , 并 分 别 定义 这 些 属性 的 setXxxO 
和 getXxx0 方 法 , 然后 在 类 中 声明 _set0 方 法 , 使 用 该 方法 为 类 中 未 声明 的 属性 赋 初 值 , 实现 该 过 程 的 代码 如 下 : 


class Book // 定 义 图 书 类 
{ 
Private $name; // 书 名 
Private $page; /页码 
Private $writer; /作者 
Private $price; /价格 
private Sother: /其 他 信息 
public function setName ($name) /设置 书 名 
{ 
Sthis->name = Sname: 
} 
public function getName | // 获 得 书 名 
etum $this->name: 
} 
public function setPage ($page) // 设 置 页 码 


{ 
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Sthis->page = Spage; 


. 
public function getPage (0) /获得 页 码 
{ 
retum $this->page; 
} 
public function setWriter ($writer) // 设 置 作者 


Sthis->writer = $writer; 


public function getWriter () /获得 作者 

Tetum $this->writer 

人 function setPrice ($price) /设置 价格 
Sthis->price = $price; 

Mie function getPrice 0 // 获 得 价格 

return $this->price; 


} 
public function __set ($name, $value) 


Sthis->other = $value: 


} 
public function getOther | 
{ 

} 

(2) 建立 图 书信 息 二 维 数组 用 于 保存 图 书信 息 ， 代 码 如 下 : 
require ‘Book.php'; 

SarrayBook = array( // 图 书信 息 数组 ， 用 于 模拟 图 书信 息 数 据 表 
le 《PHP 从 基础 到 *+*》', 'page'=>'650', "writer=>' 小 张 、 小 潘 、 小 王 ',price=>'58"), 
array(name'=>' 《PHP 函数 **》', 'page'=>'800', "writer=>' 小 潘 、 小 王 "price=>'80). 
armray(name'=>' 《PHP 范例 *#》' page'=>"700', "writer=>' 小 李 、 小 懂 ',price' 
array(name =>'《PHP 实战 *+》"'page=>"750% writer=>, 小 郭 、 小 刘 "price=>757 


Teturn $this->other; 


); 
(3) 使 用 foreach 语句 通过 循环 输出 图 书信 息 。 在 foreach 循环 体内 部 ， 首 先 对 Book 类 进行 实例 化 ， 然 后 
分 别 调用 类 中 的 setXxx0 方 法 为 类 中 已 声明 的 属性 赋 初 值 , 同时 为 类 中 未 声明 的 备注 属性 赋值 ,最 后 使 用 getXxxO 
方法 打印 出 图 书 的 信息 ， 实 现 该 过 程 的 代码 如 下 : 


<?php 
require ‘db.php'; 
foreach ($arrayBook as $key => $aBook) { 
S$book = new Book(); 
Sbook->setName($aBook[name]); 
Sbook->setPage($aBook[page]): 
S$book->setWriter($aBook["writer’]): 
S$book->setPrice($aBook['price"]); 
$book->bz =' 备 注 '; 
2 
<div style="width:100%: <?php if($key < count($arrayBook)-1){?>border-bottom: 1px solid #0463BD:<?php } ?> clear:both:"> 
<div style="width:160px: height:22px: line-height:22px: text-align:left: float:left:"> 
<?php echo $book->getName0?> 
</div> 
<div style="width:160px: height:22px: line-height:22px: border-left:1px solid #0463BD: float:left:"> 
<?php echo $book->getPage()?> 
<div> 
<div style="width:160px: height:22px; line-height22px: border-left:1px solid #0463BD: float:left:"> 
<?php echo $book->getWriter()?> 
<div> 
<div style="width:160px: height:22px: line-height:22px: border-left:1px solid #0463BD: floatleft"> 
<?php echo Sbook->getprice0?> 
</div> 
<div style="width:156px: height:22px: line-height:22px: border-left:1px solid #0463BD: float:left:"> 
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<?php echo Sbook->getOther0?> 
<Jdiv> 

<div> 

<?php }?> 


图 秘笈 心 法 


心 法 领悟 337: 在 类 体外 直接 为 类 中 未 定义 的 属性 赋 初 值 。 
在 PHP 面向 对 象 编程 中 ， 在 类 体外 可 以 直接 为 类 中 未 定义 的 属性 赋 初 值 ， 其 示例 代码 如 下 ; 


class Test /定义 类 Test 
{ 


} 


Stest = new TestO; // 对 Test 类 进行 实例 化 
Stest->x= "明日; // 为 Test 类 中 未 定义 的 属性 x 赋 初 值 
echo Stest->x; // 打 印 x 属 性 


上 述 代码 中 ， 首 先 定义 类 Test， 然 后 再 使 用 new 关键 字 对 Test 类 进行 实例 化 ， 并 使 用 该 类 实例 化 的 对 象 调 
用 类 中 未 定义 的 属性 x， 同 时 为 该 属性 赋 初 值 ， 最 后 打印 该 属性 。 运 行 上 述 代码 将 在 页 面 中 打印 出 “明日 ”二 
字 ， 从 而 说 明 即 使 在 类 中 未 定义 某 属性 ， 在 类 体外 也 可 以 对 该 属性 进行 操作 。 


| 


实例 说 明 这 个 侠 具 重 0.4sp， 是 并 色 ， 固 形 的 1 
本 实例 主要 应 用 _get0 方 法 获得 类 中 未 定义 属性 的 名 称 。 运 行 本 实例 ， | 
如 图 7.32 所 示 , 页 面 中 打印 的 内 容 是 通过 调用 苹果 类 的 属性 打印 的 结果 , 而 
弹出 的 提示 对 话 框 是 因为 没有 在 类 中 定义 SproduceArea 属性 而 通过 ”get0 方 
法 弹出 的 。 图 732 类 中 未 定义 属性 提示 杠 


图 关键 技术 


魔术 方法 ”get0 用 于 获得 类 中 不 存在 属性 的 名 称 , 该 方法 必须 带 有 一 个 表示 未 定义 属性 名 称 的 参数 ，_get0 
方法 的 使 用 格式 如 下 : 
fanction get($name) 


/在 方法 内 部 可 以 使 用 Sname 的 值 ， 该 值 即 为 未 定义 属性 的 名 称 
} 
图 设计 过 程 
(1) 定义 苹果 类 Apple， 在 该 类 中 分 别 定义 苹果 颜色 、 形 状 和 重量 等 属性 ， 并 使 用 构造 方法 对 这 些 属性 进 


行 初始 化 ， 然 后 定义 用 于 获得 苹果 属性 信息 的 getProperty( 方 法 ， 最 后 定义 _get(0 方 法 用 于 弹出 提示 未 定义 属性 
名 称 的 对 话 框 ， 实 现 该 过 程 的 代码 如 下 : 


取 未 定义 属性 的 名 称 中 级 | 


趣味 指数 : 傅 食 全 | 


class Apple 

{ 
private $color: /颜色 
Private $shape; /形状 
Private $weight; /重量 
public function ”construct ($color, $shape, Sweight) /构造 方法 


{ 
Sthis->color = $color: 
S$this->shape = $shape: 
Sthis->weight = $weight: 
;i 
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public function getProperty 0 
‘ return ' 这 个 苹果 重 ' . $this->weight .'， 是 ' . $this->color .'，' . Sthis->shape . 的 ! '; 
Ls function 。 get ($name) 


{ 1/ 使 用 _get0 方 法 弹出 未 定义 属性 的 提示 
echo '<script>alert(" 在 类 中 未 定义 属性 '. $name . '! "):</seript>'; 


} 
(2) 使 用 new 关键 字 对 苹果 类 Apple 进行 实例 化 ， 然 后 使 用 实例 化 后 的 对 象 调用 苹果 类 中 的 getProperty0 
方法 打印 苹果 的 属性 信息 ， 最 后 使 用 苹果 对 象 调用 类 中 未 定义 的 属性 ， 实 现 该 过 程 的 代码 如 下 : 


require 'Apple.php'; /使 用 require 语句 包含 Apple.php 文件 
$apple = new Apple( 红 色 ', ' 圆 形 ', '0.4kg’); /使 用 new 关键 字 对 Apple 类 进行 实例 化 
echo $apple->getProperty(; // 调 用 类 中 的 

echo Sapple->produceArea; // 调 用 类 中 未 定义 的 属性 
秘笈 心 法 


心 法 领悟 338: 使 用 _get0 方 法 实现 错误 信息 的 提示 。 
在 PHP 面向 对 象 编程 方式 中 , 为 了 防止 因 调用 类 中 未 定义 的 属性 而 导致 程序 运行 期 错误 或 程序 功能 的 不 稳 
定 ， 可 以 在 类 中 指定 _get0 方 法 实现 未 定义 属性 的 错误 信息 提示 。 


力 实例 说 明 
本 实例 主要 讲解 _call0 魔 术 方 法 的 使 用 。 运 行 本 实例 ， 如 图 7.33 所 示 ， ee 
将 在 页 面 中 打印 出 图 书 的 信息 和 调用 未 定义 方法 的 名 称 。 其 中 图 书 的 信息 是 cll 


图 书 类 调用 类 中 的 getProperty0 方 法 所 返回 的 结果 ， 而 未 定义 getInfo 方法 的 ”图 7.33 类 中 未 定义 属性 提示 框 
提示 是 通过 类 中 的 _call0 方 法 的 打印 结果 。 


力 关键 技术 


魔术 方法 _call0 在 调用 类 中 一 个 不 存在 或 不 可 见 的 方法 时 执行 ，_call0 方 法 必须 接收 两 个 参数 ， 用 来 存放 


视图 调用 的 方法 名 及 其 参数 ， 该 方法 的 语法 格式 如 下 : 
finction __call($name, $arguments) 
{ 


} 

代码 中 的 参数 Sname 用 于 表示 类 中 未 定义 方法 的 名 称 ，$arguments 用 于 表示 未 定义 方法 的 参数 所 组 成 的 
数组 。 
力 设计 过 程 

(1) 定义 图 书 类 Book， 首 先 在 该 类 中 定义 $name 和 $price 属性 ， 并 使 用 构造 方法 对 这 两 个 参数 进行 实例 
化 , 然后 定义 getProperty0 方 法 返回 图 书 属性 ， 最 后 定义 call0 方 法 打印 未 定义 方法 的 名 称 ， 实 现 该 过 程 的 代 


码 如 下 : 
class Book // 图 书 类 
4 
private $name: // 书 名 
private $price; /价格 
public function _construct (Sname. $price) /构造 方法 


{ 
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Sthis->name = $name: 
Sthis->price = $price: 
} 
public function ”call ($name, $arguments) //_call0 方 法 


{ 
echo $name . 方法 未 定义 ': 


public function getProperty 0 /获得 图 书信 息 的 方法 


return $this->name .' 的 价格 是 '. Sthis->price . ' 元 '; 
} 
} 
(2) 使 用 new 关键 字 对 Book 类 进行 实例 化 ， 然 后 使 用 实例 化 的 对 象 调用 类 中 的 getProperty0 方 法 打印 图 


书信 息 ， 最 后 使 用 实例 后 的 对 象 调用 类 中 未 定义 的 getInfo0 方 法 ， 代 码 如 下 


require ‘Book.php'; // 包 含 Book.php 文件 

SbookName ='《PHP 范例 +*》': // 书 名 

Sprice ='85'; /价格 

S$book = new Book($bookName, $price); // 对 Book 类 进行 实例 化 

echo $book->getProperty0 . ‘<br/>'; // 打 印 图 书 属性 

$book->getInfo($bookName, $price): // 调 用 类 中 未 定义 的 getInfo0 方 法 
图 秘笈 心 法 


心 法 领悟 339: 在 类 中 未 定义 _call0 魔 术 方法 时 ， 调 用 类 中 未 定义 的 方法 会 提示 错误 信息 。 
在 类 体外 可 以 使 用 类 实例 化 的 对 象 为 类 中 未 定义 的 属性 赋值 ， 但 是 如 果 类 中 没有 定义 _call0 方 法 ， 直 接 调 
用 类 中 未 定义 的 方法 时 会 提示 错误 信息 ， 通 过 如 下 示例 代码 进行 演示 。 


class Test /定义 类 Test 

{ 

} 

Stest =new TestO; // 对 Test 类 进行 实例 化 
Stest->fun(); /调用 类 中 未 定义 的 方法 


在 上 述 示 例 代码 中 ， 定 义 类 Test， 并 使 用 new 关键 字 对 其 进行 实例 化 ， 然 后 使 用 类 实例 化 的 对 象 调用 类 中 
未 定义 的 fun0 方 法 ， 将 在 页 面 打 印 如 下 错误 提示 : 


Fatal error: Call to undefined method Test::fun() in D:\AppServ\www\MR\O7\t.php on line 7 


一 ， 
办 法 将 类 的 实例 转换 为 字符 事 中 级 | 


力 实例 说 明 


加 的 半径 是 ，2 


本 实例 主要 讲解 如 何 通过 _tostring0 魔 术 方法 将 类 实例 的 对 象 转换 为 字符 Se 
串 ， 运 行 本 实例 ， 如 图 7.34 所 示 ， 在 页 面 中 打印 出 圆 的 半径 和 该 半径 对 应 的 加 0 
面积 ， 其 中 圆 的 面积 是 直接 打印 圆 类 所 实例 对 象 的 结果 。 图 734 打印 圆 的 半径 和 面积 


力 关键 技术 
魔术 方法 _toString0 的 作用 是 将 类 实例 化 的 对 象 转换 为 字符 串 ， 该 方法 的 语法 格式 如 下 


fanction _toStringO{ 
retum 字符 串 : 


} 
该 方法 的 返回 值 必须 为 字符 串 类 型 ， 如 果 在 类 中 未 定义 该 方法 ， 当 直接 输出 某 一 个 类 实例 的 对 象 时 ， 将 在 
页 面 中 打印 如 下 错误 提示 : 


Catchable fatal error: Object of class Test could not be converted to string in D:\AppServ\www\MR\O7N\027\t.php on line 3 


当 在 类 中 定义 _toString0 方 法 后 ， 直 接 输 出 类 实例 后 的 对 象 将 在 页 面 中 打印 toString0 方 法 所 返回 的 字 
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符 串 。 
力 设计 过 程 


(1) 创建 圆 类 Circle， 在 圆 类 中 定义 圆 半径 私有 属性 Sradius， 并 使 用 构造 方法 对 该 属性 进行 初始 化 ， 然 后 
定义 _toStringO 魔 术 方 法 ， 使 用 该 方法 返回 圆 的 面积 值 ， 代 码 如 下 : 


class Circle /定义 圆 类 

{ 
Private Sradius; // 圆 半径 属性 
public function __construct ($radins) // 构 造 方法 


S$this->radius = $radius; 
} 
public function _toString 0 /定义 _toString(0 方 法 


{ 
retum " 圆 的 面积 是 : " . (string) number format((pi0 * pow(S$this->radius, 2)), 2); 


} 
(2) 使 用 require 语句 包含 Circle.php 文件 , 然后 设 定 圆 的 半径 为 2， 并 使 用 echo 语句 输出 圆 的 半径 和 圆 类 
实例 的 对 象 ， 代 码 如 下 : 


require 'Circle.php'; // 包 含 Cirele php 文件 
Sradius = 2; // 贺 半径 

echo ' 圆 的 半径 是 :'.$radius.<br/>'; // 打 印 贺 半 径 的 值 
echo new Circle($radius); /打印 圆 面积 


心 法 领悟 340; 使 用 number format0 函 数 对 数字 进行 格式 化 输出 。 
在 对 数字 、 货 币 等 数值 型 数据 进行 操作 时 ， 经 常 需要 对 数字 进行 格式 化 输出 ，PHP 中 提供 了 专门 对 数字 进 


行 格式 化 输出 的 函数 number_format0， 其 语法 格式 如 下 : 
string number_format ( float number [, int decimals [, string dee point string thousands_sep]] ) 


参数 说 明 : 

number: 必要 参数 ， 指 定 要 进行 格式 化 的 字符 串 。 

decimals: 可 省 参数 ， 指 定 要 保留 小 数 的 位 数 ， 如 果 省 略 ， 该 参数 则 保留 3 位 小 数 。 

dec_point: 可 省 参数 ， 用 该 参数 指定 的 字符 蔡 代 小 数 点 ， 该 参数 与 参数 thousands_sep 同时 使 用 。 
thousands_sep: 可 省 参数 ， 用 该 参数 指定 的 字符 蔡 代 千 位 分 隔 符 ， 该 参数 与 参数 dec_point 同时 使 用 。 


力 实例 说 明 


运行 本 实例 ， 如 图 7.35 所 示 ， 在 页 面 中 打印 出 未 定义 属性 的 提示 信息 以 及 小 明 的 年 龄 和 体重 信息 ， 其 中 类 
中 未 定义 属性 sex 的 提示 信息 是 通过 魔术 方法 _isset0 打 印 的 。 


在 类 中 未 定义 属性 sex 


小 明 的 年 龄 是 ，12 岁 ， 体 重 是 ，45 公 斤 


图 7.35 打印 人 的 属性 信息 
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图 关键 技术 
魔术 方法 _isset0 是 当 使 用 isset0 函 数 判 断 类 中 未 定义 的 属性 是 否 被 设置 时 所 调用 的 ， 该 方法 的 使 用 格式 
如 下 : 


function _isset ($name) 


{ 


} 

魔术 方法 _isset0 必 须 包 含 一 个 用 于 代表 类 中 未 定义 属性 的 名 称 参数 。 
图 设计 过 程 

(1) 定义 人 类 Person， 在 该 类 中 定义 人 的 名 称 、 年 龄 和 体重 等 属性 ， 并 定义 与 这 些 属 性 相对 应 的 setXxx() 
方法 和 getXxx0 方 法 ， 代 码 如 下 : 


class Person 
private $name; // 名 称 
Private $age; /年 龄 
private $weight; 1/ 体重 
public function setName ($name) /设置 名 称 
S$this->name = Sname: 
Lp, function getName (0 /获得 名 称 
: retum $this->name; 
ny function setAge ($age) // 设 置 年 龄 
S$this->age = $age; 
ns function getAge 0 // 获 得 年 龄 
return $this->age; 
ne function setWeight ($weight) /设置 体重 
Sthis->weight = $weight; 
a function getWeight () /获得 体重 
return $this->weight: 
i function _isset ($name) // 定 义 _isset0 方 法 


echo ' 在 类 中 未 定义 属性 '. Sname: 
} 
. 


(2) 使 用 new 关键 字 对 Person 类 进行 实例 化 , 然后 分 别 调用 该 类 中 相应 的 setXxx0 方 法 为 类 中 的 属性 赋 初 
值 ， 并 使 用 函数 isset0 判 断 类 中 未 定义 的 sex 属性 是 否 被 设置 ， 实 现 该 过 程 的 代码 如 下 : 


require 'Person.php'; // 包 含 Person.php 文件 

S$person = new Person(); // 对 Person 类 进行 实例 化 
Sperson->setName( 小 明 '); // 设 置 名 称 

Sperson->setAge('12"): /设置 年 龄 
S$person->setWeight(45 公斤 "); /设置 体重 

isset($person->sex); /判断 是 否 在 类 中 定义 了 sex 属性 
echo ‘<br/>"; /换行 


echo $person->getName0. 的 年 龄 是 : 'Sperson->getAgs0.' 岁 ， 体 重 是 : 'Sperson->getWeightO ; /打印 信息 
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心 法 领悟 341: 使 用 issetO 函 数 判 断 变量 是 否 被 设置 值 。 
PHP 编码 时 ， 有 时 需要 判断 某 一 变量 是 否 被 设置 了 值 ， 然 后 再 对 该 变量 进行 操作 ，PHP 中 可 以 使 用 issetO 
函数 判断 某 个 变量 是 否 被 设置 了 值 ， 该 函数 的 使 用 格式 如 下 : 


bool isset ( mixed var [, mixed var [, 了) 
如 果 该 函数 的 参数 列表 所 指定 的 变量 都 已 经 设置 了 值 ， 则 该 函数 返回 TRUE， 反 之 返回 FALSE。 


ee ， 
去 提示 未 定义 属性 信息 中 级 | 
2 起 味 指数 : 庚 雄 雪 “| 


图 实例 说 明 


本 实例 主要 讲解 魔术 方法 _unset0 的 使 用 方法 。 运行 本 实例 , 如 图 7.36 a 
所 示 , 在 页 面 中 打印 出 使 用 unsetO 函 数 撤销 类 中 未 定义 的 价格 属性 的 结果 。 图 7.36 打印 Car 类 中 未 定义 的 属性 


力 关键 技术 
魔术 方法 _unsetO 是 当 使 用 unset0 函 数 撤销 类 中 未 定义 的 属性 时 所 调用 的 ， 该 方法 的 使 用 格式 如 下 : 


function _unset ($name) 


{ 


} 

魔术 方法 _unset0 必 须 包 含 一 个 用 于 代表 类 中 未 定义 属性 的 名 称 参数 。 
图 设计 过 程 

(1) 建立 汽车 类 Car， 在 类 中 定义 汽车 的 品牌 和 颜色 属性 ， 然 后 使 用 构造 方法 为 这 两 个 属性 赋 初 值 ， 最 后 
定义 魔术 方法 _unset0 打 印 撤销 类 中 未 定义 属性 时 的 提示 信息 ， 代 码 如 下 : 


class Car 

{ 
private $brand; // 品 牌 
private $color: /颜色 
public function ”construct ($brand, $color) // 构 造 方法 


Sthis->brand = $brand; 
Sthis->color = Scolor 

a function _unset ($name) // 定 义 _unset0 方 法 
echo ' 在 '. CLASS _.' 类 中 未 定义 '. Sname . ' 属 性 '; 

} 

} 
(2) 使 用 require 语句 包含 Car.php 文件 ， 然 后 使 用 new 关键 字 对 汽车 类 进行 实例 化 并 生成 汽车 对 象 $car， 
最 后 使 用 unset0 方 法 撤销 类 中 未 定义 的 价格 属性 ， 代 码 如 下 : 


Tequire 'Car.php'; // 包 含 Car.php 文件 

S$car = new Car( 奥 过" ' 黑 色 "): /使 用 new 关键 字 实例 Car 类 

unset($car->price); /使 用 unset0 函 数 释放 Car 类 中 未 定义 的 属性 price 
力 秘笈 心 法 


心 法 领悟 342: PHP 中 的 魔术 常量 。 
本 实例 中 ， 使 用 _CLASS_ 获 得 当前 类 的 名 称 ， 类 似 这 样 的 常量 在 PHP 中 被 称 为 魔术 常量 ， 其 中 PHP 中 
常用 的 魔术 常量 及 其 说 明 如 表 7.1 所 示 。 
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表 7.1 PHP 中 常用 的 魔术 常量 


魔术 常量 名 称 说 明 
_LNE | 返回 运行 中 PHP 脚本 的 当前 行 的 行 号 
FIE | 返回 当前 PHP 脚本 的 完整 路 径 和 文件 名 
_FUNCTION | 返回 当前 函数 的 名 称 
CLASS | 返回 当前 类 的 名 称 
_METHOD 返回 当前 类 中 成 员 方法 的 名 称 
实 八 | 
实例 343 趣味 指数 : 请 请 良 
图 实例 说 明 
草 果 是 乱 色 的 
本 实例 主要 讲解 如 何 使 用 魔术 方法 “autoload0 自 动 加 载 类 文件 。 运行 eh 


本 实例 ， 如 图 7.37 所 示 ， 在 页 面 中 分 别 打印 出 苹果 和 桔子 的 颜色 信息 。 

在 实现 本 实例 时 ， 将 Apple 类 和 Orange 类 分 别 存放 在 与 这 两 个 类 同 。 图 737 打印 苹果 和 桔子 的 颜色 属性 
名 的 类 文件 中 ， 然 后 在 index.php 文件 中 不 使 用 require 等 包含 语句 包含 这 两 个 类 文件 ， 而 使 用 _autoload0 方 法 
根据 类 名 自动 导入 相应 的 文件 。 


图 关键 技术 


魔术 方法 _autoload0 包 含 一 个 参数 ， 该 参数 是 当前 页 面 中 所 定义 类 的 名 称 ， 在 该 魔术 方法 内 部 ， 可 以 使 用 
require 等 包含 语句 和 该 方法 的 参数 所 代表 的 类 名 来 自动 加 载 类 ，_autoload0 的 使 用 格式 如 下 : 


function __autoload(Sname){ 


} 


图 设计 过 程 
(1) 定义 苹果 类 Apple 和 桔子 类 Orange， 并 分 别 在 这 两 个 类 中 定义 用 于 获得 颜色 的 getColor0 方 法 ， 代 码 
如 下 : 
二 // 便 果 类 
public function getColor 0 /获得 苹果 颜色 的 方法 
retum "苹果 是 红色 的 ': 
1 
} 
class Orange /桔子 类 
public function getColor 0 /获得 桔子 颜色 的 方法 
{ 
retum ' 桔 子 是 橙色 的 : 


} 


} 
(2) 定义 _autoload0 方 法 的 实现 。 在 该 方法 内 部 首先 构建 自动 包含 类 文件 的 路 径 ， 然 后 使 用 file_exists() 
函数 判断 该 文件 是 否 存在 ， 如 果 存 在 ， 则 使 用 require_once 语句 包含 该 文件 ， 反 之 返回 FALSE 值 ， 实 现 该 过 程 


的 代码 如 下 : 
function _autoload ($className) // 定 义 _autoload0 方 法 
{ 
Sfile=dimame(_ FILE ).'/class/. $className . '.php'; // 包 含 文件 的 路 径 
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if(! file_exists($file)) { // 判 断 文 件 是 否 存在 
retum false: /不 存在 返回 FALSE 
j elkse{ 
require_once $file; // 存 在 则 包含 该 文件 


(3) 使 用 require 语句 包含 autoload.php 文件 ， 然 后 使 用 new 关键 字 分 别 对 苹果 类 和 桔子 类 进行 实例 化 ， 
最 后 通过 这 两 个 类 实例 的 对 象 分 别 调用 各 自 的 getColor0 方 法 打印 苹果 和 桔子 的 颜色 ， 代 码 如 下 : 


require 'autoload php': /包含 autoload.php 文件 
S$apple = new Apple(); /对 苹果 类 进行 实例 化 
Sorange = new Orange(); /对 桔子 类 进行 实例 化 
echo $apple->getColor0 .<br/>"; /打印 苹果 颜色 
echo $orange->getColor0: /打印 桔子 颜色 
We 
国 秘笈 心 法 


心 法 领悟 343: 使 用 file_exists0 函 数 判断 指定 的 文件 是 否 存在 。 
本 实例 中 ， 在 魔术 方法 _autoload0 内 部 使 用 fle_exists0 函 数 判断 指定 的 类 文件 是 否 存在 ， 该 函数 的 语法 格 
式 如 下 


bool file_exists ( string filename ) 


如 果 filename 指定 的 文件 或 目录 存在 则 返回 TRUE， 否 则 返回 FALSE。 
7.8 设计 模式 


面向 对 象 的 程序 开发 方式 不 仅 表现 在 程序 的 语法 规则 和 语言 特性 上 ， 更 主要 的 是 表现 一 种 设计 思想 。 当 设 
计 一 个 软件 时 ， 很 多 设计 概念 被 反复 使 用 ， 最 终 形成 了 一 种 规则 ， 这 些 规则 通常 被 称 为 设计 模式 。 本 节 将 通过 
具体 实例 讲解 PHP 常用 设计 模式 的 应 用 方式 。 


| 


实例 说 明 

本 实例 主要 讲解 如 何 使 用 单 例 模式 制作 一 个 基于 MySQL 数据 库 的 数据 库 管理 类 。 运 行 本 实例 ， 如 图 7.38 
所 示 ， 首 先 在 用 户 登录 文本 框 中 输入 用 户 名 和 密码 ， 然 后 单 击 表单 中 的 “登录 ”按钮 ， 如 果 用 户 名 和 密码 经 后 
台 代 码 验 证 正确 则 当前 页 面 将 跳 转 到 登录 成 功 信息 提示 页 面 ， 如 果 错误 则 在 页 面 打印 错误 提示 。 在 上 述 过 程 中 ， 
对 数据 库 管理 模块 的 开发 采用 PDO 技术 ， 设 计 上 采用 单 例 模式 进行 编码 。 


En 


地 叶柄 数 : 贾 宙 宙 | 


用 户 登 录 


(0 999010E TR 


图 7.38 用 户 登 录 表单 
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图 关键 技术 


单 例 模式 指 的 是 在 程序 应 用 范围 内 只 对 指定 的 类 创建 一 个 实例 ， 也 就 是 说 单 例 模式 只 包含 一 个 对 象 ， 就 是 


单 例 本 身 ，PHP 使 用 单 例 模式 设计 的 类 通常 应 该 满足 如 下 要 求 : 


名” 单 例 模式 的 类 通常 拥有 一 个 私有 的 构造 方法 和 一 个 私有 的 克隆 方法 ， 这 样 可 以 确保 用 户 无 法 通过 创建 


对 象 或 者 克隆 的 方式 对 其 进行 实例 化 。 


回 “” 单 例 模式 的 类 包含 一 个 静态 的 用 于 保存 当前 类 实例 的 成 员 变 量 ， 以 及 一 个 静态 方法 ， 该 静态 方法 负责 
对 其 本 身 进行 实例 化 ， 然 后 将 实例 化 后 的 对 象 保存 到 类 中 所 声明 的 静态 变量 中 ， 从 而 确保 一 个 对 象 被 


创建 。 
PHP 单 例 模式 的 基本 形式 如 下 : 
class Singleton 
{ 
Private static $instance; // 保 存 当 前 类 实例 后 的 对 象 
public static function getInstance 0 // 静 态 方 法 ， 返 回 类 实例 
if (null =— self::$instance) { // 如 果 未 定义 
self::$instance = new Db(); 
} 
retum self::$instance; // 返 回 当前 对 象 
} 
private function construct () // 私 有 构造 方法 
0 
private function _clone () // 私 有 克隆 方法 
0 
/类 的 其 他 方法 
} 
/获得 类 的 对 象 


Ssingleton = Singleton::getInstance(); 
由 上 述 代码 可 知 , 在 类 外 部 通过 类 名 直接 调用 类 中 的 用 于 返回 当前 类 实例 的 静态 方法 即 可 获得 当前 类 实例 。 


图 设计 过 程 
(1) 建立 数据 库 连 接 类 Db, 在 类 中 定义 用 于 保存 当前 类 实例 的 静态 成 员 变量 $instance， 并 定义 静态 方法 
getInstace()。 在 该 方法 内 部 ， 将 当前 类 实例 的 对 象 赋 给 静态 成 员 变 量 $instance 并 返回 ， 然 后 定义 私有 的 构造 


方法 和 克隆 方法 , 这 样 就 构建 了 单 例 模式 的 基本 框架 。 接 下 来 创建 getConnId0 方 法 , 该 方法 用 于 返回 使 用 PDO 
技术 连接 数据 库 后 的 句柄 ， 最 后 创建 数据 库 查 询 方法 query0 实 现 对 数据 库 的 查询 操作 。 实 现 上 述 过 程 的 代码 


如 下 : 
class Db /| 数据 库 类 
{ 

Private static $instance; // 保 存 当 前 类 实例 后 的 对 象 

public static function getInstance () // 静 态 方法 ， 返 回 类 实例 
f(null 一 self::$instance) { /如 果 未 定义 

self::$instance = new DbO): 

} 
return self::$instance: 

} 

private function construct () // 私 有 构造 方法 

0 

Private function _clone 0 // 私 有 克隆 方法 

8 

Pprivate function getConnId (0) // 获 得 数据 库 连 接 ID 的 方法 

{ 
Sconfig = parse_ini file(dimame( FILE_ ).'/config.ini’): // 解 析 配 置 文 件 
$dsn = 'mysql:host=" . $config['host] . :dbname=’ . $config['dbname']: // 配 置 数据 源 名 称 
S$pdo = new PDO($dsn, $config['usemame'], $config['password']): // 实 例 PDO 对 象 
S$pdo->query('set names '. $config['charset]): // 设 置 字符 集 
retum $pdo: /返回 PDO 对 象 
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1 
public function query ($sql) /查询 方法 
{ 
$pdo = $this->getConnIdO; /获得 PDO 对 象 
$sqlType = trim(substr($sql, 0, 6)); // 获 得 查询 语句 类 型 
if($sqlType — ‘update' | $sqlType 一 'delete | $sqlType 一 ‘insert) { 
retum $pdo->query(Ssq]): // 如 果 是 update、delete 或 insert 语句 则 返回 SQL 语句 执行 结果 
} elseif ($sqlType — 'select) { // 如 果 是 select 语句 
StmpArray = array(O); // 定 义 二 维 数组 
lts = $pdo->query($sqD): /| 执行 select 语句 
foreach ($results as Sresult) { // 将 结果 保存 到 二 维 数组 中 
) array_push($tmpArray, $result); 
retum StmpArray: /返回 结果 
}else{ 
retum null; // 不 是 update、delete、insert 或 select 语句 ， 则 返回 null 


} 


} 
(2) 建立 用 户 登录 表单 ， 其 实现 过 程 请 详 见 本 书 光盘 。 当 用 户 在 表单 中 输入 用 户 名 和 密码 ， 单 击 “ 提 交 ” 


按钮 后 ， 将 通过 如 下 代码 验证 用 户 的 登录 信息 是 否 正确 。 
ifisset($_POST[usemame]) && trim($_POST['usemame'])!=") 
和 


_POST[usemame]): 
S$password = trim(md5($_POST[password"])): 
S$db = Db::getInstance(); 
SarrayUser = $db->query("select id from tb_user where usemame=".$usermame.”" and password =".$password.™"); 
这 count(SarrayUseD>0){ 
$_SESSION[loginUsemame]= $usermame; 


echo ‘<script>window.location.href="success.php";</script>"; 
yelse { 


echo ‘<div style="width:300px; height30px: line-height:30px: border:1px solid #E59B04; background-color:#FCF2E0; color#FF0000:"> 用 户 
Wi 误 </div>'; 
上 述 代码 首先 判断 用 户 是 否 提 交 了 表单 ， 如 果 是 ， 则 通过 Db 类 的 getInstance0 方 法 获得 类 的 实例 ， 并 通过 
该 对 象 调用 类 中 的 query0 方 法 执行 查询 ， 根 据 查询 结果 的 记录 数 来 判断 用 户 输入 的 用 户 名 和 密码 是 否 正确 ， 如 
果 记 录 数 大 于 1， 则 说 明 用 户 登录 信息 有 效 。 


国 秘笈 心 法 


心 法 领悟 344: 使 用 parse_ini_file0) 函 数 解析 .ini 文件 。 
在 项 目 开发 中 , 经 常 需要 将 项 目的 一 些 配置 参数 保存 到 .ini 文件 中 , 例如 本 实例 将 数据 库 连 接 参 数 保存 到 专 
门 的 config.ini 文件 中 ， 以 便于 对 项 目 配置 信息 的 修改 和 统一 管理 。parse_ini_file0 函 数 的 语法 格式 如 下 ;: 


Poree ni (tn na tool Process sectons]) 

parse_ini file0 函 数 载 入 一 个 由 fename 指定 的 .ini 文件 ， 并 将 其 中 的 设置 作为 一 个 联合 数组 返回 。 如 果 
process_sections 参数 设 为 TRUE， 将 得 到 一 个 多 维 数组 ,包括 配置 文件 中 每 一 节 的 名 称 和 设置 ，process_sections 
的 默认 值 是 FALSE。 


3 
着 窗户 端 浏览 器 关 型 中 级 | 
实例 345 超 味 指教 : 傅 良 请 | 
实例 说 明 


本 实例 主要 讲解 在 PHP 面向 对 象 编程 中 策略 模式 的 应 用 方法 。 运 行 本 实例 ， 分 别 如 图 7.39 和 图 7.40 所 示 ， 
其 中 图 7.39 所 示 为 在 正 浏览 器 下 运行 的 结果 ， 图 7.40 所 示 为 在 火狐 浏览 器 下 运行 的 结果 。 从 运行 结果 可 知 ， 
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本 实例 会 根据 不 同 浏览 器 的 类 型 在 页 面 中 打印 相应 浏览 器 的 名 称 。 


3 
盖 泪 人 0 | 乔 http://e2.168 1 sojnrJor/ss/ 了 | [3 


当前 浏览 器 是 IE 


[Bb 


[ml 
图 7.39 打印 浏览 器 的 类 型 为 正 


图 关键 技术 


同 机 训 


图 7.40 打印 浏览 器 的 类 型 是 Firefox 


策略 模式 指 的 是 程序 中 涉及 决策 控制 的 一 种 模式 。 策 略 模式 通常 定义 一 个 抽象 基 类 ， 然 后 根据 不 同情 况 创 


建 不 同 的 子 类 ， 其 中 一 个 简单 的 策略 模式 框架 如 下 : 


abstract class Strategy 
abstract public function fun 0: 
有 Childl extends Strategy 
。 public function fun 0 
//Child1 中 fan0 方 法 所 实现 的 功能 


} 
class Child2 extends Strategy 
public function fun 0) 
VChild2 中 fan0 方 法 所 实现 的 功能 


} 
这 条 件 1 一 tmue){ 

S$obj = new Child10: 
jelsef 

S$obj = new Child20: 
} 


// 定 义 抽象 的 基 类 

/定义 抽象 方法 fun0 

/定义 子 类 Child1， 使 其 继承 基 类 Strategy 
/实现 fun0 方 法 的 功能 


/定义 子 类 Child2， 使 其 继承 基 类 Strategy 
/实现 fun0 方 法 的 功能 


// 如 果 条 件 1 为 真 
/| 生成 子 类 Childl 的 实例 对 象 


// 生 成 子 类 Child2 的 实例 对 象 


S$obj->fun(); 
上 述 示例 代码 中 首先 定义 抽象 基 类 Strategy, 并 在 类 中 定义 抽象 方法 fun(), 然 后 分 别 定义 类 Childl 和 Child2， 
使 这 两 个 类 分 别 继承 基 类 Strategy， 在 这 两 个 子 类 的 内 部 实现 fun0 的 功能 ， 完 成 以 上 类 的 定义 后 ， 就 可 以 根据 


不 同 的 条 件 对 不 同 的 子 类 进行 实例 化 。 
力 设计 过 程 


(1) 定义 抽象 的 Browser 类 ， 并 在 该 类 中 声明 抽象 方法 getType0， 然 后 定义 子 类 Ie 和 Fox， 使 这 两 个 类 分 
别 继承 基 类 Browser， 然 后 在 类 体内 完成 对 getType0 方 法 的 定义 ， 代 码 如 下 : 


abstract class Browser 
abstract public function getType |: 


} 

class Ie extends Browser 

{ 
public function getType 0 
{ 


retum TE'; 
} 


} 
class Fox extends Browser 
{ 
public function getType 0 
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/定义 抽象 类 Browser 


/定义 下 类 
/获得 类 型 方法 


/定义 Fox 类 
/获得 类 型 方法 
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Teturn Firefox'; 


} 
(2) 使 用 header0 函 数 设 置 页面 编 码 ,并 使 用 require 语句 包含 Browserphp 文件 ,然后 定义 getBrowserType0 
方法 获得 浏览 器 类 型 ， 代 码 如 下 : 


header('content-type:text/html; charset=utf-8"); // 定 义 页 面 编码 
require ‘Browser.php'; // 包 含 Browser.php 文 ， 
function getBrowserType 0 人 人文 贡 于 的 
{ 
f(strstr($_SERVER['HTTP USER AGENT]. "IE") { // 判 断 是 否 为 正 浏览 器 
$b =new Ie0; // 实 例 二 类 
j else{ 
Sb =new Fox0; 1/ 实例 Fox 类 
本 
retumn $b->getType0: // 返 回 浏览 器 类 型 
} 
echo ' 当 前 浏览 器 是 '. getBrowserType(); /执行 getBrowserType0 方 法 
秘笈 心 法 


心 法 领悟 345: 使 用 header0 函 数 设 置 页 面 编 码 。 
通过 HTML 语言 的 <meta> 标 记 可 以 设置 页 面 编码 ， 那 么 如 果 在 不 包含 任何 HTML 标记 的 PHP 页 面 中 如 何 


设置 页 面 编码 呢 ? PHP 提供 了 用 于 发 送 HTTP 头 信息 的 header0 函 数 ， 可 以 通过 如 下 方式 设置 页 面 编 码 。 
header('content-type:text/html; charset=utf-8") 


上 述 代 码 可 以 设置 文件 的 内 容 类 型 为 text/html， 页 面 编 码 为 UTF-8 编码 。 


实例 346 


图 实例 说 明 


本 实例 主要 讲解 如 何 使 用 工厂 模式 对 用 户 权限 进行 管理 。 运 行 本 实例 ， 如 图 7.41 所 示 ， 在 页 面 中 将 打印 出 
不 同 用 户 的 类 型 及 各 项 操作 的 访问 权限 。 制 作 本 实例 时 ， 首 先 创建 抽象 的 用 户 权限 类 ， 然 后 分 别 定义 浏览 、 添 
加 、 更 改 和 删除 等 子 类 ， 使 之 继承 基 类 用 户 权限 类 ， 然 后 根据 不 同 用 户 的 权限 ， 重 写 用 户 权限 类 中 的 方法 ， 最 
后 创建 用 户 权限 工厂 来 根据 不 同 用 户 类 别 返 回 相应 的 对 象 。 
项 尊 约克 癌 | 3 


Ce 
a 


Www.mrbocd.com 


人 Ag 页 
管 二 三 一 -一 一 一 一 一 一 一 | ww | * | # | | 
| rr | 会 EE 法 sl 
mm ||| 
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图 7.41 电子 相册 用 户 权限 列表 
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图 关键 技术 


工厂 模式 是 指 创建 一 个 类 似 于 工厂 的 类 ， 通 过 对 类 中 成 员 方法 的 调用 返回 不 同类 型 的 对 象 。 使 用 工厂 模式 
时 ， 首 先 创 建 一 个 基 类 ， 然 后 根据 对 象 类 型 的 不 同 来 创建 不 同 的 扩展 类 ， 最 后 定义 工厂 类 来 根据 不 同 的 条 件 返 


回 相 应 的 对 象 。 工 厂 模式 的 示例 代码 如 下 : 
abstract class Father /定义 基 类 
{ 


} 
class Child1 extends Father // 定 义 子 类 1 


{ 
} 
class Child2 extends Father // 定 义 子 类 2 
{ 
class Factory // 定 义工 厂 类 
{ 

public static function create ($condition) // 创 建 对 象 


让 (Scondition 一 ' 条 件 1) { 
retum new Child10): 
} elseif (Scondition 一 ' 条 件 2) { 
retum new Child20; 
} 
' } 
上 述 示 例 代码 中 ， 首 先 定 义 抽 象 基 类 Father， 然 后 定义 子 类 Childl 和 Child2， 使 之 分 别 继承 基 类 Father， 
在 实际 应 用 中 还 应 该 重 写 或 定义 子 类 Childl 和 Child2 中 的 方法 ， 最 后 定义 工厂 类 Factory， 并 在 该 类 中 定义 静 
态 的 create() 方 法 来 根据 不 同 的 条 件 返回 相应 的 对 象 。 


他 提示 : 抽象 基 类 也 可 以 使 用 接口 来 代替 。 
图 设计 过 程 

(1) 定义 用 户 权限 基 类 UserPermission， 然 后 在 该 基 类 中 定义 select0、add0、edit0 和 delete0 等 方法 ， 然 后 分 
别 定义 子 类 GuestPermission、MemberPermission 和 AdminPermission， 并 使 这 些 类 分 别 继承 基 类 UserPermission。 同 


时 根据 不 同类 的 功能 对 基 类 中 的 方法 进行 重 写 , 最 后 定义 用 户 权 限 工厂 UserPermissionFactory, 根据 不 同 用 户 的 类 别 
对 相应 的 子 类 进行 实例 化 并 返回 ， 实 现 该 过 程 的 代码 如 下 : 


abstract class UserPermission // 定 义 抽象 的 用 户 权 限 类 
1 public function select 0 /定义 查询 方法 

return true; 

ne function add 0 /定义 添加 方法 

， return false; 

人 function edit 0 /定义 编辑 方法 

eturm false; 

Le function delete (|) /定义 删除 方法 

Tetum false: 
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class GuestPermission extends UserPermission /定义 浏览 者 权限 类 
0 
class MemberPermission extends UserPermission // 定 义 会 员 权限 类 
{ 
public function add 0 // 重 写 添加 方法 
{ 
return true; 
;| 时 
class AdminPermission extends UserPermission // 定 义 管理 员 权限 类 
{ 
public function add 0 // 重 写 添加 方法 
{ 
return true; 
} 
public function edit 0 // 重 写 编辑 方法 
{ 
return true; 
3 
public function delete 0 // 重 写 删除 方法 
下 
return true; 
; 
class UserPermissionFactory // 用 户 权 限 工厂 
{ 
public static function getUser ($userType) // 获 得 用 户 权限 方法 
{ 
switch ($userType) { 
case 'GUEST': 
return new GuestPermission(); /返回 普通 浏览 者 权限 对 象 
break:; 
case MEMBER': 
return new MemberPermission(): 1/ 返回 会 员 权 限 对 象 
break; 
case 'ADMIN': 
return new AdminPermission(); // 返 回 管理 员 权限 对 象 
break 


} 
} 
(2) 定义 二 维 数组 Susers， 使 用 该 数组 保存 用 户 名 称 及 权限 类 别 ， 代 码 如 下 : 
Susers = array( 
0=>array(name'=>' 大 麦 ', 'type' => 'GUEST), 
1=>array(name'=>'SOFT. type' => 'MEMBER'),. 
2=>array(name'=>' 春 泉 ', 'type' => 'GUEST), 
3=>array(name'->' 金 星 , 'type' => 'GUEST), 
4->amray(name'=>'360' type' => MEMBER'). 
5=>amay(name=>MR' type => ,ADMIN) 


G3) 使 用 require 语句 包含 UserPermissionFactory.php 及 db.php 文件 ， 然 后 使 用 foreach 循环 语句 遍历 用 户 
数组 ， 并 根据 用 户 类 别 通过 用 户 权 限 工 三 生成 相应 的 用 户 权限 对 象 ， 最 后 打印 用 户 权限 信息 ， 实 现 该 过 程 的 代 


) 


码 如 下 : 
php 
require "UserPermissionFactory.php'; // 包 含 用 户 权限 工厂 所 在 文件 
require 'db.php'; // 包 含 用 户 信息 数 组 所 在 文件 
foreach ($users as $user){ /遍历 用 户 权 限 数组 
SuserPermission = UserPermissionFactory::getUser(Suserftype]): // 获 得 用 户 权限 对 象 
> 
<!-- ”以 下 代码 用 于 打印 用 户 权 限 信息 -> 
<tr> 


<td style="width:80px; height:22px; border: 1px solid #E0056F:"><?=$user['name']?></td> 

<td style="width:80px: height:22px: border: 1px solid #E0056F:"><?=str_replace(ADMIN", "管理 员 ', str_replace(MEMBER', ' 会 员 '， 
str_replace(GUEST' ' 访 客 ' Suser['type))?></td> 

<td style="width:80px: height:22px; border:1px solid #E0056F:"><?=$userPermission->select0?' 是 ; 否 ?></td> 
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<td style="width:80px; height22px: border:1px solid 赋 0056F:"><?-SuserPemmission->add0? 是 … 否 ?><itd> 
<td style="width:80px; height:22px; border:1px solid #E0056F:"><?=$userPermission->edit0? 是 ' 
<td style="width:80px; height:22px:; border:1px solid #E0056F:"><?=$userPermission->delete0?' 是 '' 否 ?></td> 

<itr> 

<?php 

} 


心 法 领悟 346， 使 用 工厂 模式 设计 数据 库 管理 类 。 


根据 本 实例 所 介绍 的 工厂 模式 可 知 ， 如 果 采 用 该 模式 设计 数据 库 管 理 类 ， 可 以 使 用 相同 的 代码 实现 对 不 同 


数据 库 的 管理 。 采 用 工厂 模式 设计 数据 库 管理 类 的 模板 代码 如 下 : 
abstract class Db // 定 义 抽象 的 数据 库 管理 类 


abstract public function insert (); 
abstract public function delete (); 
abstract public function update (); 
abstract public function select (); 


De MySQL extends Db /定义 MySQL 数据 库 管理 类 
. public fanction insert 0) 

es function delete 0) 

a function update 0 

pu function select 0) 


} 
class Oracle extends Db // 定 义 Oracle 数据 库 管理 类 
{ 


public function insert 0) 
0 
public function delete 0) 


0 

public function update 0 
0 

public function select 0) 
0 


a SQLServer extends Db // 定 义 SQL Server 数据 库 管理 类 
: public function insert 0) 

ys function delete () 

让 function update () 

pie function select 0 


} 
class DbFactory // 定 义 数据 库 管理 类 工厂 
{ 
public static finction getDb (STYPE) // 根 据 不 同 的 标识 返回 不 同 的 数据 库 实 例 
{ 
switch (STYPE) { 
case MYSQL': 
return new MySQLO: 
break: 
case 'ORACLE': 
return new Oracle(): 
break; 
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case 'SQLSERVER': 
retum new SQLServer(); 
break: 
} 
} 


} 

在 上 述 模板 代码 中 ， 首 先 定义 抽象 的 数据 库 管 理 类 Db， 然 后 分 别 定义 子 类 MySQL、Oracle 和 SQL Server， 
并 定义 数据 库 管 理 类 工厂 DbFactory， 在 该 工厂 中 定义 静态 方法 getDb0， 用 来 根据 不 同 的 标识 返回 数据 库 管 理 
类 对 象 ， 这 样 通过 该 对 象 就 可 以 实现 采用 相同 的 方法 对 不 同 数据 库 进 行 管理 。 
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第 9 章 MySQL 高 级 应 用 技术 

第 10 章 PHP 操作 SQL Server 数据 库 
第 11 章 PHP 操作 Access 数据 库 

第 12 章 PHP 操作 Oracle 数据 库 
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MySQL 数据 库 与 PHP 


让 MySQL 服务 路 的 启动 和 关闭 
MW” ”MySQL 数据 库 

MW” MySQL 数据 表 

”MySQL 数据 

MW PHP 操作 MySQL 数据 库 
”SQL 查询 语句 

MW 多 表 查 询 

WH 数据 的 导入 和 导出 

MH MySQL 数据 库 的 备份 和 恢复 
”phpMyAdmin 图 形 化 管理 工具 


第 8 章 MySQL 数据 库 与 PHP 
8.1 MySQL 服务 器 的 启动 和 关闭 


PHP 在 开发 Web 站 点 或 一 些 管理 系统 时 ， 需 要 对 大 量 数据 进行 存储 。XML 文件 和 文本 文件 虽然 可 以 作为 
数据 的 载体 ， 但 不 易 进 行 管理 和 对 大 量 数据 的 存储 ， 所 以 在 项 目 开发 时 ， 数 据 库 就 显得 非常 重要 。PHP 可 以 连 
接 的 数据 库 种 类 较 多 ， 其 中 MySQL 数据 库 与 其 兼容 较 好 ， 在 PHP 开发 中 被 广泛 应 用 。 
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看 实例 说 明 

如 果 想 学 习 PHP 语言 ， 那 么 就 必须 要 学 MySQL。PHP 与 MySQL 是 最 佳 的 组 合 ， 虽 然 PHP 现在 支持 更 多 
的 数据 库 , 如 Access、SQL Server、Oracle、DB2 等 , 但 是 无 论 在 LAMP 组 合 (Linux + Apache + MySQL + PHP)， 
还 是 AMP 组 合 (Apache + MySQL + PHP) 中 ，MySQL 的 地 位 丝毫 没有 动摇 。 

在 Windows 操作 系统 中 ， 启 动 MySQL 服务 器 可 以 使 用 命令 模式 进行 。 


图 关键 技术 


本 实例 的 关键 是 在 命令 提示 符 下 输入 启动 MySQL 服务 器 的 命令 , 完成 MySQL 服务 器 的 启动 , 其 命令 如 下 : 
net start mysql 
图 设计 过 程 
在 Windows 操作 系统 下 启动 MySQL 服务 器 的 步 又 如 下 : 
(1) 在 Win7/Win8 系统 下 ， 使 用 Windows+R 快捷 键 打开 “运行 ”对 话 框 ， 在 “打开 ”文本 框 中 输入 cmd 
命令 ， 按 Enter 键 进入 命令 提示 符 窗口 ， 如 图 8.1 所 示 。 
(2) 在 命令 提示 符 下 输入 启动 MySQL 服务 器 的 命令 ， 如 图 8.2 所 示 。 
本 全 为 您 打开 检点 的 程序 


打开 Q)， emd 局 


NET HELPMSG 2182 


8.1 进入 命令 提示 符 窗口 图 8.2 成 功 启动 MySQL 服务 器 


心 法 领悟 347: 手动 启动 MySQL 服务 器 。 
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启动 MySQL 服务 器 还 有 另外 一 种 方法 ， 即 通过 选择 “开始 ”/“ 控 制 面板 ”/“ 管 理工 具 ”/“ 服 务 ” 命 令 ， 
打开 Windows 服务 管理 器 ， 在 服务 器 的 列表 中 找到 MySQL 服务 ， 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “启动 ” 命 
令 即 可 。 


四 实例 说 明 


启动 MySQL 服务 器 只 是 应 用 MySQL 的 第 一 步 ， 如 果 想 要 操作 MySQL 数据 库 ， 就 要 学 会 连接 MySQL 服 
务 器 。 本 实例 详细 讲解 如 何在 命令 提示 符 下 连接 MySQL 服务 器 。 


图 关键 技术 
选择 “开始 ”/“ 运 行 ”命令 ， 输 入 cmd 命令 ， 进 入 命令 提示 符 窗口 ， 在 其 中 输入 如 下 命令 : 


mysql -uName -p Password 
“mysql” 与 “-u”、“Name” 与 “-p” 之 间 有 一 个 空格 。Name 表示 进入 MySQL 服务 器 的 用 户 名 ; Password 
表示 进入 MySQL 服务 器 的 密码 。 
图 设计 过 程 
连接 MySQL 服务 器 的 步骤 如 下 : 
(1) 进入 命令 提示 符 窗 口 。 


(2) 如 果 MySQL 默 认 安 装 在 C 盘 根 目录 下 ,在 未 设置 环境 变量 的 情况 下 , 须 在 命令 提示 符 下 进入 mysql\bin 
文件 夹 ， 输 入 命令 。 假 设 用 户 名 为 root， 密 码 为 111， 输 入 的 命令 如 下 : 


mysql -uroot -pl11 
按 Enter 键 ， 输 出 如 图 8.3 所 示 的 内 容 ， 表 示 连 接 MySQL 成 功 。 
(3) 如 果 在 本 地 用 户 机 上 运行 程序 ， 可 以 直接 输入 命令 mysql -uroot -p111 来 连接 MySQL, 但 是 为 了 保证 
安全 ， 避 免 他 人 得 到 连接 MySQL 数据 库 的 密码 进行 非法 操作 ， 最 好 使 用 如 下 命令 : 


mysql -uroot -了 


并 根据 提示 输入 密码 完成 连接 ， 如 图 8.4 所 示 。 


图 8.3 连接 MySQL 成 功 图 8.4 连接 MySQL 成功 


国 秘笈 心 法 


心 法 领悟 348: 设置 MySQL 环境 变量 。 
在 连接 MySQL 数据 库 时 ， 可 以 通过 设置 环境 变量 PATH 连接 MySQL， 这 样 用 户 无 须 手动 进入 MySQL 的 
bin 文件 夹 ， 可 以 直接 输入 命令 连接 MySQL。 设 置 MySQL 环境 变量 的 步骤 如 下 : 
(1) 右 击 “ 我 的 电脑 ”， 在 弹出 的 快捷 菜单 中 选择 “属性 ”/“ 高 级 ”/“ 环 境 变量 ”命令 。 
(2) 在 Administrator 的 用 户 变量 下 选择 PATH 变量 ， 单 击 “ 编 辑 ” 按 钮 ， 在 弹出 的 文本 框 中 添加 MySQL 
安装 文件 中 bin 文件 夹 的 位 置 ， 如 “:C:\mysql\bin”， 单 击 “确定 ” 按 钮 ， 环 境 变量 配置 完毕 。 
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(3) 在 命令 提示 符 下 输入 如 下 命令 : mysql -uroot -p111。 
(4) 按 Enter 键 ， 输 出 如 图 8.3 所 示 的 内 容 ， 连 接 MySQL 成 功 。 


实例 349 趣味 指数 : 友 雪 友 雪 : 
力 实例 说 明 


为 了 有 效 节 省 系统 资源 ， 在 进行 MySQL 数据 库 操作 后 ， 需 要 及 时 将 MySQL 服务 关闭 。 关 闭 MySQL 服务 
的 方法 与 启动 MySQL 服务 相似 ， 可 以 通过 两 种 方法 实现 。 通 过 本 实例 ， 相 信用 户 会 将 关闭 MySQL 服务 器 的 两 
种 方法 熟 记 于 心 。 


图 关键 技术 


在 命令 提示 符 下 ， 输 入 命令 : 
(1) 断 开 MySQL 数据 库 连 接 。 
exit 
(2) 关闭 MySQL 服务 。 


net stop mysql 
图 设计 过 程 
(1) 在 命令 提示 符 下 ,输入 命令 连接 MySQL， 通 过 MySQL 数据 库 函 数 user 显示 数据 表 中 的 内 容 ， 如 
图 8.5 所 示 。 


图 8.5 查询 表 信息 


(2) 通过 exit 命令 断 开 与 MySQL 的 连接 ， 如 图 8.6 所 示 。 
(3) 输入 命令 net stop mysql， 按 Enter 键 ， 关 闭 MySQL 服务 ， 如 图 8.7 所 示 。 


图 8.6 ” 断 开 与 MySQL 连接 图 8.7 关闭 MySQL 服务 


秘笈 心 法 

心 法 领悟 349: 手动 停止 MySQL 服务 。 

关闭 MySQL 服务 还 有 另外 一 种 方法 ， 即 通过 选择 “开始 ”/“ 控 制 面板 ”/“ 管 理工 具 ”/“ 服 务 ” 命 令 ， 打 
开 Windows 服务 管理 器 ， 在 服务 列表 中 找到 MySQL 服务 ， 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “停止 ”命令 即 可 ， 
如 图 8.8 所 示 。 
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Comee, 


选择 “停止 ”命令 | | 


8.2 MySQL 数据 库 


MySQL 是 一 款 安全 、 跨 平台 、 高 效 ， 并 与 PHP、Java 等 主流 编程 语言 紧密 结合 的 数据 库 系 统 。 该 数据 库 系 
统 由 瑞典 的 MySQL AB 公司 开发 、 发 布 并 支持 ， 由 MySQL 的 初始 开发 人 员 David Axmark 和 Michael Monty 
Widenius 于 1995 年 建立 。MySQL 的 象征 符号 是 一 只 名 为 Sakila 的 海豚 ， 代 表 着 MySQL 数据 库 的 速度 、 能 力 、 
精确 和 优秀 本 质 。 


图 实例 说 明 


如 果 用 户 已 经 掌握 如 何 启动 、 连 接 、 断 开 和 关闭 MySQL 服务 器 ， 下 面 就 学 习 创建 数据 库 。 创 建 数据 库 的 
主要 目的 是 将 同类 的 或 者 是 同一 个 项 目 中 的 数据 表 进 行 分 类 存储 ， 方 便 开发 人 员 查 找 和 使 用 。 本 实例 通过 数据 
库 函 数 CREATE DATABASE 创建 PHP 图 书 数据 库 。 


图 关键 技术 


(1) 创建 数据 库 函数 。 


CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name: 
CREATE DATABASE 用 于 创建 数据 库 ， 并 进行 命名 。 参 数 db_name 表示 需要 创建 的 数据 库 名 称 。 
(2) 获取 数据 库 列 表 。 


SHOW {DATABASES | SCHEMAS} [LIKE pattem]: 
SHOW DATABASES 可 以 列举 数据 库 名 称 。 


图 设计 过 程 
(1) 进入 命令 提示 符 窗口 ， 启 动 MySQL 服务 ， 连 接 MySQL 服务 器 。 
(2) 通过 数据 库 函 数 在 命令 提示 符 下 编写 命令 ， 代 码 如 下 : 


CREATE DATABASE DB MRBOOK: 
按 Enter 键 ， 运 行 结果 如 图 8.9 所 示 。 
(3) 查看 MySQL 数据 库 列 表 ， 查 找 创建 的 PHP 图 书 数据 库 是 否 存在 ， 运 行 结果 如 图 8.10 所 示 。 


高 级 
趣味 指数 : 交友 友 兢 | 
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图 8.9 创建 数据 库 db_mrbook 图 8.10 数据 库 db_mrbook 存在 于 数据 库 列表 中 
(4) 断 开 数据 库 连接 ， 关 闭 MySQL 服务 。 
秘笈 心 法 


心 法 领悟 350: 数据 库 命名 规则 。 

在 创建 数据 库 时 ， 数 据 库 命名 要 遵循 以 下 几 项 规则 。 

加 ”不 能 与 其 他 数据 库 重 名 ， 否 则 将 发 生 错 误 。 

加 ”名 称 可 以 由 任意 英文 字母 、 阿 拉 伯 数字 、 下 划 线 或 者 $8 组成， 可 以 使 用 上 述 的 任意 字符 开头 ， 但 不 能 
使 用 单独 的 数字 ， 否 则 会 造成 数据 库 名 与 数值 相 混 淆 。 

回 “名称 最 长 可 为 64 个 字符 ， 而 别名 最 长 可 达 256 个 字符 。 

回 ”不 能 使 用 MySQL 关键 字 作为 数据 库 、 表 名 。 

加 ”默认 情况 下 ，Windows 系统 下 是 不 区 分 数据 库 名 、 表 名 的 大 小 写 的 ， 而 在 Linux 系统 下 要 区 分 数据 库 
名 、 表 名 的 大 小 写 。 为 了 便于 数据 库 在 平台 间 进 行 移植 ， 建 议 采 用 小 写 来 定义 数据 库 名 和 表 名 。 


高 级 | 


实例 351 趣味 指数 : 窒 伍 丰 : 


力 实例 说 明 


创建 数据 库 的 目的 是 向 数据 库 中 存储 同类 型 或 者 同一 个 项 目下 

的 所 有 数据 表 。 若 用 户 已 经 创建 了 数据 库 ， 需 要 通过 命令 选择 指定 

的 数据 库 ， 否 则 计算 机 将 无 法 自动 识别 创建 的 数据 表 属于 哪个 数据 a 

库 ， 还 会 出 现 错误 提示 ， 如 图 8.11 所 示 。 图 8.11 错误 提示 
本 实例 通过 数据 库 函 数 USE db_name 实现 选择 PHP 图 书 数据 库 。 


图 关键 技术 


使 用 USE db_name 语句 可 以 通过 MySQL 把 db_name 数据 库 作为 默认 当前) 数据 库 ， 并 应 用 于 后 续 语句 。 
该 数据 库 保持 为 默认 数据 库 ， 直 到 语 段 的 结尾 ， 或 者 直到 发 布 一 个 不 同 的 USE 语句 ， 语 法 格式 如 下 : 


USE db_name: 


参数 db_name 表示 需要 使 用 的 数据 库 名 称 ， 该 名 称 必须 是 合法 的 。 
图 设计 过 程 
(1) 在 命令 提示 符 窗 口 下 ， 通 过 命令 启动 MySQL 服务 ， 连 接 MySQL 服务 器 。 创 建 数据 库 并 将 此 数据 库 
命名 为 db_mrbook。 
(2) 通过 show databases; 语 句 ， 查 看 在 MySQL 服务 器 主机 上 列举 的 数据 库 名 称 是 否 包含 用 户 指定 的 数据 库 。 


(3) 输入 命令 use db_mrbook;， 将 数据 库 db_mrbook 作为 当前 默认 数据 库 ， 按 Enter 键 ， 命 令 窗 口 将 输出 
如 图 8.12 所 示 的 内 容 。 
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图 8.12 选择 数据 库 
(4) 关闭 数据 库 连接 ， 关 闭 MySQL 服务 。 


心 法 领悟 351: USE 语句 的 特点 。 
使 用 USE 语句 为 一 个 特定 的 当前 的 数据 库 做 标记 ， 不 会 阻碍 访问 其 他 数据 库 中 的 表 ， 例 如 : 


use dbl; 
select * from db2.tb2; 


在 cmd 命令 提示 符 下 ， 把 数据 库 dbl 作为 当前 数据 库 标记 ， 访 问 数据 库 db2 下 表 tb2 中 所 有 的 数据 ， 这 样 
做 也 是 正确 的 。 


实例 352 


力 实例 说 明 


若菜 个 数据 库 失去 了 存在 的 价值 ， 那 么 为 了 节省 系统 硬盘 资源 ， 提 高 MySQL 的 运行 效率 ， 建 议 将 其 从 硬 
盘 上 删除 。 删 除数 据 库 可 以 通过 打开 MySQL 安装 目录 进入 data 文件 夹 删 除 指定 的 数据 库 文件 夹 ， 还 可 以 通过 
在 命令 提示 符 下 输入 删除 命令 。 本 实例 讲解 在 命令 提示 符 下 输入 命令 ， 实 现 删除 PHP 图 书 数 据 库 。 


图 关键 技术 


DROP DATABASE 语句 用 于 删除 数据 库 中 的 所 有 表格 和 数据 库 。 使 用 此 语句 需要 获得 数据 库 DROP 权限 ， 
其 语法 格式 如 下 : 
DROP {DATABASE | SCHEMA} [IF EXISTS] db_name; 
图 设计 过 程 
(1) 进入 命令 提示 符 窗口 ， 启 动 MySQL 服务 ， 连 接 MySQL 服务 器 。 
(2) 通过 命令 语句 show databases; 查 看 在 MySQL 服务 器 主机 上 列举 的 数据 库 名 称 是 否 存 在 数据 库 
db_mrbook。 
(3) 使 用 命令 语句 use db_mrbook: 为 数据 库 db_mrbook 做 上 标记 , 使 其 为 当前 默认 数据 库 , 如 图 8.13 所 示 。 
(4) 在 命令 行 输入 drop database db_name: 语 句 ， 删 除数 据 库 的 同时 也 删除 数据 库 中 的 所 有 表 ， 所 以 在 命令 
行 输入 命令 删除 数据 库 时 ， 最 好 清查 数据 库 中 的 所 有 表 名 ， 以 防止 意外 删除 运行 程序 中 的 作用 表 而 造成 不 必要 
的 损失 。 查 看 数据 库 中 所 有 表 名 可 以 通过 命令 语句 show tables; 实 现 ， 如 图 8.14 所 示 。 
(5) 使 用 命令 行 语句 删除 PHP 图 书 数据 库 db_mrbook， 如 图 8.15 所 示 。 
(6) 断 开 与 MySQL 服务 器 的 连接 ， 关 闭 MySQL 服务 。 


图 8.13 选择 数据 库 图 8.14 显示 数据 库 中 的 数据 表 图 8.15 删除 数据 库 
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心 法 领悟 352: 屏蔽 删除 不 存在 数据 库 提 示 。 

在 命令 提示 符 窗口 中 ， 输 入 删除 不 存在 的 数据 库 命令 ， 会 发 生 1008 错误 ， 提 示 无 法 删除 指定 数据 库 ， 因 为 
指定 数据 库 不 存在 。 如 果 用 户 想 屏蔽 此 错误 提示 ， 可 以 使 用 数据 库 删 除 语句 drop database db _name: 中 的 可 选 参 
数 fexists。 例 如 ， 输 入 命令 语句 drop database if exists tb_123;， 则 无 论 是 否 存 在 tb_123 数据 库 ， 命 令 行 会 一 直 
提示 操作 成 功 ， 如 图 8.16 所 示 。 


图 8.16 ”删除 不 存在 数据 库 


8.3 MySQL 数据 表 


创建 完 数据 库 后 ， 就 可 以 在 命令 提示 符 下 对 数据 库 进行 操作 了 ， 如 创建 数据 表 、 更 改 数据 表 结构 以 及 删除 
数据 表 等 。 


实例 353 


实例 说 明 


数据 库 的 主要 作用 是 保存 数据 表 ， 而 数据 表 的 作用 是 保存 数据 
信息 。 本 实例 通过 CREATE TABLE 语句 实现 在 PHP 图 书 数据 库 中 
创建 图 书信 息 表 ， 如 图 8.17 所 示 。 


图 关键 技术 
创建 数据 表 使 用 CREATE TABLE 语句 ， 其 语法 格式 如 下 : 


CREATE TABLE table name 
(create_definition,...) 
[table_opotions] 
[select_statement] 


参数 说 明 : 

table name: 要 创建 的 数据 表 名 。 

create_definition: 表 的 列 属性 部 分 。MySQL 要 求 创建 的 表 至 少 包 含 一 列 。 
table_options: 表 的 一 些 特性 参数 。 

select_ statement: SELECT 语句 描述 部 分 ， 可 以 快速 地 创建 表 。 

下 面 介绍 列 属 性 部 分 ， 每 一 列 定义 的 具体 格式 如 下 : 


col_name type[NOT NULL |NULL][DEFAULT default value][AUTO_INCREMENTI][PRIMARY KEY] 

参数 说 明 : 

col name: 表示 字段 名 。 

type: 表示 字段 类 型 。 

NOT NULL 或 者 NULL: 指出 该 列 是 否 允 许 是 空 值 。 所 谓 的 空 值 是 “不 知道 ”或 “无 意义 ”的 值 ， 但 是 数 
据 “0” 和 空格 都 不 是 空 值 ， 系 统一 般 默 认 允 许 为 空 值 ， 所 以 当 不 允许 为 空 值 时 ， 必 须 使 用 NOTNULL。 


图 8.17 创建 数据 表 
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DEFAULT default_value: 表示 默认 值 。 

AUTO _INCREMENT: 表示 是 否 自动 编号 ， 每 个 表 只 能 有 一 个 AUTO_INCREMENT 列 ， 并 且 必 须 被 索引 。 

了 PRIMARY KEY: 表示 是 否 为 主键 。 它 是 唯一 的 KEY, 还 有 一 个 额外 的 约束 , 即 所 有 键 列 必须 被 定义 为 NOT 
NULL。 在 MySQL 中 ， 该 列 被 命名 为 PRIMARY。 一 个 表 只 能 有 一 个 PRIMARY KEY。 如 表 中 没有 PRIMARY 
KEY， 而 某 些 应 用 程序 需要 时 ，MySQL 将 返回 第 一 个 没有 任何 NULL 列 的 UNIQUE 键 作 为 PRIMARY KEY。 
一 个 PRIMARY KEY 可 以 是 一 个 多 列 索引 ， 但 是 不 能 在 一 个 列 规格 说 明 中 使 用 PRIMARY KEY 键 属性 来 创建 
一 个 多 列 索引 ， 这 样 做 将 仅仅 标记 单个 列 作为 主键 ， 必 须 使 用 PRIMARY KEY(index_col name,….) 名 法。 如果 
PRIMARY KEY 或 UNIQUE 键 只 由 一 个 列 组 成 ， 并 且 列 类 型 是 整 型 ， 则 可 以 用 _rowid 引用 。 

以 上 是 创建 数据 表 的 一 些 基础 知识 ， 在 实际 的 应 用 中 ， 只 要 使 用 最 基本 的 格式 创建 数据 表 即 可 ， 具 体格 式 
Te table table_name( 列 名 1 属性 , 列 名 2 属性 …) 

图 设计 过 程 
(1) 启动 MySQL 服务 ， 建 立 MySQL 服务 器 连接 。 
(2) 在 命令 提示 符 窗口 下 通过 命令 语句 create database db_mrbook: 创 建 名 称 为 db_mrbook 的 数据 库 。 
(3) 使 用 use db_mrobook: 语 句 设 定数 据 库 标 记 。 
(4) 通过 create table tb_mrbook(); 语 句 创建 数据 表 ， 代 码 如 下 : 


mysql> use db_mrbook; 

Database changed 

mysql> create table tb_mrbook( 
-> id int(4) auto_increment prima 
-> name varchar(20) NOT NULL, 
-> pwd varchar(20) NOT NULL); 

Query OK, 0 rows affected (0.05 sec) 


(5) 断 开 MySQL 服务 器 连接 ， 结 束 MySQL 服务 。 
图 秘笈 心 法 
心 法 领悟 353: SQL 语句 格式 。 


在 输入 SQL 语句 时 ， 可 以 一 行 全 部 输出 ， 也 可 以 每 个 字段 都 换行 输出 ， 这 里 建议 用 换行 输出 ， 因 其 看 上 去 
美观 、 易 懂 ， 且 在 语句 出 现 错误 时 更 容易 查找 。 


力 实例 说 明 


查看 信息 表 分 两 种 形式 : 第 一 种 是 查看 信息 表 结 构 ， 第 二 种 是 查看 信息 表 数 据 。 实 例 353 通过 create table 
tb_name; 创 建 的 只 是 表 结 构 ， 并 没有 插入 数据 信息 ， 如 果 想 查看 信息 表 数 据 信息 ， 需 要 使 用 select 查询 语句 。 本 
实例 通过 show columns 语句 查看 信息 表 结 构 ， 运 行 结果 如 图 8.18 所 示 。 


图 8.18 查看 信息 表 结 构图 
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图 关键 技术 


使 用 show columns 语句 查看 数据 表 结 构 ， 其 语法 如 下 : 
show [full] columns from 数据 表 名 [from 数据 库 名 ];: 


或 写成 
show [fnll] columns ”from 数据 表 名 .数据 库 名 ; 
图 设计 过 程 
(1) 开启 MySQL 服务 ， 在 命令 提示 符 窗口 输入 命令 ， 创 建 MySQL 连接 。 通 过 create database db_name; 
和 create table tb_name:; 语 句 创建 数据 库 和 数据 表 。 


(2) 通过 命令 语句 show columns from tb_name: 查 看 表 结构 ， 其 代码 如 下 : 
mysql> show columns from tb_mrbook: 


(3) 通过 exit 和 net stop mysql; 语 句 断 开 数 据 库 服 务 器 ， 并 关闭 MySQL 服务 。 


心 法 领悟 354: describe 语句 的 特点 。 


查看 数据 表 结 构 还 可 以 通过 describe 语句 。describe 语句 的 语法 格式 如 下 : 
describe 数据 表 名 ; 


其 中 ，describe 可 以 简写 成 desc。 在 查看 表 结 构 时 ， 也 可 以 只 列 出 某 一 列 的 信息 ， 其 语法 格式 如 下 : 
describe 数据 表 名 列 名 ; 


实例 355 


实例 说 明 


程序 员 在 建立 数据 表 时 ， 难 免 在 表 的 结构 上 出 现 错误 ， 例 如， 
将 Date 类 型 数据 设置 为 int 类 型 ， 这 时 就 需要 更 改 表 的 结构 。 本 
实例 通过 增加 表 tb_mrbook 中 的 last_date 字段 ， 并 设置 数据 类 型 
为 Date 实现 修改 信息 表 ， 运 行 结果 如 图 8.19 所 示 。 


力 关键 技术 


修改 表 结构 是 指 增加 或 者 删除 字段 、 修 改 字段 名 称 或 者 字段 类 型 、 设 置 取消 主键 外 键 、 设 置 取消 索引 以 及 
修改 表 的 注释 等 。 修 改 表 结 构 采用 alter table 语句 ， 其 语法 如 下 : 


alter [IGNORE] table 数据 表 名 alter_spee[.alter_spec] 
注意 ， 当 指定 IGNORE 时 ， 如 果 出 现 重复 行 则 只 执行 一 行 ， 其 他 重复 行 被 删除 。 其 中 ，alter_spec 子 句 定义 
要 修改 的 内 容 ， 其 语法 如 下 : 


8.19 ”修改 图 书信 息 表 


alter_specification: 
ADD [COLUMN] create_definition [FIRST | AFTER column_name ] 一 添加 新 字段 
| ADD INDEX [index_name] (index_col name....) 一 添加 索引 名 称 
| ADD PRIMARY KEY (index_col name....) 一 添加 主键 名 称 
| ADD UNIQUE [index_name] (index_col name,...) 一 添加 唯一 索引 
| ALTER [COLUMN] col_name {SET DEFAULT literal | DROP DEFAULT} -修改 字段 名 称 
| CHANGE [COLUMN] old_col name create_definition 一 修改 字段 类 型 
| MODIFY [COLUMN] create_definition 一 修改 子 句 定义 字段 
| DROP [COLUMN] col name 一 删除 字段 名 称 
| DROPPRIMARY KEY 一 删除 主键 名 称 
| DROP INDEX index name 一 删除 索引 名 称 
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| RENAME [AS]new tbl name 一 更 改 表 名 
| table_options 


图 设计 过 程 

(1) 开启 MySQL 服务 器 ， 在 命令 提示 符 窗 口 下 创建 MySQL 连接 。 通 过 create database db _name; 和 create 
table tb_name; 语 句 创建 数据 库 和 数据 表 。 

(2) 使 用 命令 语句 show columns from tb_name: 查 看 表 结 构 。 

(3) 在 命令 提示 符 下 输入 如 下 命令 : 


mysql> alter table tb_mrbook add last_date Date; 
按 Enter 键 ， 运 行 结果 如 图 8.19 所 示 。 
(4) 通过 exit 和 net stop mysql; 语 句 断 开 数 据 库 服 务 器 并 关闭 MySQL 服务 。 


心 法 领悟 355: alter table 语句 的 特点 。 
alter table 语句 允许 指定 多 个 动作 ， 其 动作 间 使 用 逗号 分 隔 ， 每 个 动作 表示 对 表 的 一 个 修改 。 


高 级 
趣味 指数 : 伍 食 食 丰 : 


. 


实例 356 


实例 说 明 


MySQL 数据 表 是 不 允许 重 命名 的 ， 所 以 在 同一 个 数据 库 中 绝 
对 不 会 出 现 两 个 名 称 相同 的 表 , 但 是 一 般 情况 下 , 程序 员 希 望 自己 
创建 的 数据 表 更 能 贴近 自己 的 项 目 ,所 以 对 数据 表 重 命名 有 时 是 不 


可 避免 的 ,本 实例 通过 rename table 语句 实现 对 图 书信 息 表 重 命 名 ， 图 8.20 重 命 名 图 书信 息 表 
运行 结果 如 图 8.20 所 示 。 
图 关键 技术 


重 命 名 数据 表 采 用 rename table 语句 ， 语 法 格式 如 下 : 
rename table 数据 表 名 1 to 数据 表 名 2: 


或 者 
alter table 数据 表 名 1 rename 数据 表 名 2: 
图 设计 过 程 
(1) 在 命令 提示 符 窗口 下 开启 MySQL 服务 器 服务 ， 连 接 MySQL 数据 库 ， 创 建 数据 库 并 建立 数据 表 。 
(2) 使 用 命令 语句 show tables; 显 示 当前 数据 库 中 的 所 有 表 。 
(3) 在 命令 提示 符 下 输入 如 下 命令 : 


mysql> alter table tb_mrbook rename tb_mrbook php: 
按 Enter 键 完成 数据 表 的 重 命名 操作 ， 运 行 结果 如 图 8.20 所 示 。 
(4) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 


国 秘笈 心 法 
心 法 领悟 336: rename 语句 的 特点 。 
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使 用 “rename table 数据 表 名 1 to 数据 表 名 2” 语 句 可 以 同时 对 多 个 数据 表 进 行 重 命 名 ， 多 个 表 之 间 以 逗号 
“,” 分 隔 。 


高 级 | 
趣味 指数 : 依依 靖 公 


实例 357 


力 实例 说 明 


使 用 drop database db_name; 语 句 删 除数 据 库 的 同时 会 连带 删除 
数据 库 中 的 所 有 数据 表 ， 如 果 只 想 删除 数据 库 中 的 某 个 表 而 保留 其 
他 所 有 表 ， 显 然 此 语句 已 经 不 再 适用 。 删 除数 据 库 中 某 个 数据 表 可 
以 使 用 drop table tb_name:; 语 句 ， 运 行 结果 如 图 8.21 所 示 。 


| | 关键 技术 图 8.21 删除 数据 库 中 指定 数据 表 


删除 数据 表 的 操作 很 简单 ， 同 删除 数据 库 的 操作 类 似 ， 使 用 drop table 语句 就 可 以 实现 ， 其 语法 格式 如 下 : 
drop table 数据 表 名 ; 
图 设计 过 程 
(1) 在 命令 提示 符 窗口 下 开启 MySQL 服务 ， 通 过 输入 命令 连接 到 MySQL 服务 器 。 
(2) 使 用 命令 语句 show tables; 显 示 当 前 数据 库 中 的 所 有 表 。 


(3) 在 命令 提示 符 下 输入 如 下 命令 ， 删 除 指定 数据 表 。 
drop table tb_mrbook_php; 


按 Enter 键 ， 运 行 结果 如 图 8.21 所 示 。 
(4) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 


图 秘笈 心 ; 
心 法 领悟 357; 屏蔽 删除 不 存在 数据 表 的 错误 提示 。 


在 删除 数据 表 的 过 程 中 , 如 果 删 除 一 个 不 存在 的 表 将 会 产生 错误 , 这 时 在 删除 语句 中 加 入 fexists 关键 字 就 


不 会 出 错 ， 其 语法 格式 如 下 : 
drop table if exists 数据 表 名 ; 


8.4 MySQL 数据 


前 面 介 绍 了 对 数据 库 和 数据 表 的 操作 ， 它 们 是 包含 与 被 包含 的 关系 ， 即 数据 库 包含 数据 表 ， 数 据 表 被 包含 
于 数据 库 。 而 数据 表 中 包含 数据 ， 在 MySQL 数据 库 中 真正 被 调用 的 是 某 个 数据 库 中 数据 表 里 的 数据 ， 因 此 如 
何 更 好 地 操作 和 使 用 这 些 数据 才 是 使 用 MySQL 数据 库 的 根本 。 


实例 358 


力 实例 说 明 
建立 数据 库 是 为 了 把 不 同类 型 或 者 不 同 要 求 的 数据 分 类 存储 在 不 同 的 数据 表 中 ， 即 创建 数据 表 是 为 了 将 相 
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同类 型 或 者 相同 要 求 的 数据 存储 在 同一 个 表 中 。 本 实例 讲解 通过 SQL 语句 向 图 书信 息 表 中 添加 数据 ， 运 行 结果 
如 图 8.22 所 示 。 


图 8.22 向 图 书信 息 表 中 添加 数据 


力 关键 技术 


建立 一 个 空 的 数据 表 时 ， 首 先 要 想到 的 就 是 如 何 向 数据 表 中 添加 数据 。 这 项 操作 可 以 通过 insert 语句 来 实 
现 。insert 语句 的 语法 如 下 : 

insert into 数据 表 名 (column_name,column_name2, … ) values (valuel, value2, ... ); 
图 设计 过 程 

(1) 在 命令 提示 符 窗口 下 开启 MySQL 服务 ， 通 过 命令 行 语句 连接 MySQL 服务 器 ， 创 建 数 据 库 并 建立 数 
据 表 。 

(2) 编辑 insert 语句 ， 执 行 数据 的 添加 操作 ， 其 代码 如 下 : 


insert into tb_mrbook_php(id.name,pwd,last_date)values (",'lizhonghua',5315'nowO): 


(3) 当 命 令 提示 符 窗口 出 现 如 图 8.23 所 示 的 内 容 时 ， 表 示 数 据 添 加 成 功 。 


8.23 ”数据 添加 成 功 
(4) 通过 select 语句 查询 数据 表 中 的 内 容 ， 显 示 结 果 如 图 8.22 所 示 。 
(5) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 


和 秘笈 心 法 


心 法 领悟 358: insert 语句 的 特点 。 
在 MySQL 中 ， 一 次 可 以 同时 插入 多 行 记录 ， 各 行 记 录 的 值 在 values 关键 字 后 以 逗号 “,” 分 隔 ， 而 标准 的 
SQL 语句 一 次 只 能 插入 一 行 。 


实例 359 


力 实例 说 明 
用 户 向 数据 表 中 插入 数据 信息 时 ， 如 在 手动 输入 过 程 中 出 现 错误 ， 就 需要 使 用 SQL 语句 对 错误 的 数据 进行 


趣味 指教 : 容 廊 廊 评 
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修改 。 本 实例 通过 修改 语句 ， 修 改 图 书信 息 表 中 操作 数据 表 的 时 间 ， 运 行 结果 如 图 8.24 所 示 。 


图 8.24 ”修改 图 书信 息 表 


力 关键 技术 


执行 修改 操作 应 用 的 是 update 命令 ， 该 语句 的 语法 格式 如 下 : 

update 数据 表 名 set column_namel = new_valuel,column_name2 = new_value2, where condition 

其 中 ，set 子 句 指出 要 修改 的 列 及 其 给 定 的 值 ，where 子 句 是 可 选 的 ， 如 果 给 出 该 子 句 将 指定 记录 中 哪 一 行 
应 该 被 更 新 ， 否 则 所 有 的 记录 行 都 将 被 更 新 。 


力 设计 过 程 
(1) 在 命令 提示 符 窗口 下 开启 MySQL 服务 ， 通 过 命令 行 语句 连接 MySQL 服务 器 ， 创 建 数据 库 并 建立 数 
据 表 。 


(2) 使 用 select 语句 查询 图 书信 息 表 ， 如 图 8.24 中 @ 所 示 。 
(3) 使 用 update 语句 更 新 数据 表 中 的 数据 ， 其 代码 如 下 : 


update tb_mrbook_php set last_date=2010-07-11' where id=1:; 


(4) 当 命 令 提示 符 窗口 出 现 如 图 8.25 所 示 的 内 容 时 ， 表 示 数 据 更 新 成 功 。 


图 8.25 ”修改 成 功 提示 


(5) 通过 select 语句 查询 数据 表 中 的 内 容 ， 显 示 结 果 如 图 8.24 中 四 所 示 。 
(6) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 


力 秘笈 心 法 


心 法 领悟 359: 使 用 where 子 句 的 注意 事项 。 
修改 数据 信息 时 一 定 要 保证 where 子 句 的 正确 性 ， 一 旦 where 子 句 出 错 ， 有 可 能 会 破坏 所 有 的 数据 信息 。 
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实例 360 


力 实例 说 明 


删除 数据 表 中 的 所 有 数据 在 实际 开发 中 是 不 多 见 的 ， 删 除数 据 表 中 的 所 有 数据 意味 着 清空 数据 表 中 的 所 有 
信息 ， 如 果 是 操作 上 的 失误 造成 数据 表 中 所 有 信息 丢失 ， 对 于 程序 员 来 说 是 灾难 性 的 ， 所 以 对 数据 表 中 信息 
的 删除 操作 需要 十 分 谨慎 .本 实例 通过 两 种 方法 实现 删除 图 书信 息 表 中 的 所 有 数据 ,运行 结果 如 图 8.26 和 图 8.27 
所 示 。 


图 8.26 清空 数据 库 图 8.27 delete 语句 删除 信息 


图 关键 技术 


(1) 使 用 delete 语句 删除 数据 信息 ， 其 语法 如 下 : 
delete [low_priority] [quick] [ignore] from tbl_name 
[where where_definition] 
[order by ..] 
[limit row_count] 


该 语句 在 执行 过 程 中 ， 删 除 tbl_name 表 中 的 记录 ， 如 果 没有 指定 where 条 件 ， 将 删除 所 有 的 记录 ; 如 果 指 
定 where 条 件 ， 将 按照 指定 的 条 件 进行 删除 。 参 数 ORDER BY 表示 按 条 件 排序 ， 参 数 LIMIT row_count 表示 控 
制 显示 条 数 。 
(2) 使 用 truncate 语句 清空 数据 表 信息 ， 其 语法 如 下 : 


truncate [table] tb_name: 


用 于 完全 清空 数据 表 ， 从 逻辑 上 说 ， 该 语句 与 用 于 删除 所 有 行 的 delete 语句 等 同 。 
图 设计 过 程 
(1) 开启 MySQL 服务 ， 通 过 命令 提示 符 窗口 创建 MySQL 连接 ， 新 建 数据 库 和 数据 表 ， 将 数据 表 命 名 为 


tb_mrbook， 利 用 insert 插入 语句 向 数据 表 中 插入 数据 ， 并 通过 select 语句 查询 数据 表 。 
(2) 利用 truncate 语句 清空 数据 表 中 的 所 有 数据 ， 其 代码 如 下 : 


truncate tb_mrbook:; 
运行 结果 如 图 8.26 所 示 。 
(3) 利用 delete 语句 删除 所 有 数据 ， 其 代码 如 下 : 


delete from tb_mrbook: 
运行 结果 如 图 8.27 所 示 。 


力 秘笈 心 法 
心 法 领悟 360: 按 id 删除 数据 。 


在 实际 的 应 用 中 ， 在 执行 删除 操作 时 ， 执 行 删除 的 条 件 一 般 应 该 为 数据 的 id 而 不 是 具体 的 某 个 字段 值 ， 这 
样 可 以 避免 一 些 不 必要 的 错误 发 生 。 
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实例 361 看 的 指定 数据 


实例 说 明 


删除 图 书信 息 表 中 的 所 有 数据 或 者 说 清空 数据 表 的 方法 在 实际 
编程 中 是 很 少见 的 ， 一 般 都 是 删除 指定 的 一 条 或 几 条 数据 。 本 实例 通 
过 delete 语句 的 子 句 实现 删除 图 书信 息 表 中 的 指定 数据 ， 运 行 结果 如 
8.28 所 示 。 


图 关键 技术 


本 实例 的 关键 点 是 where 条 件 句 的 灵活 运用 。where 子 句 用 来 选取 需要 检索 的 记录 。 因 为 一 个 表 通 常会 有 数 
千 条 记录 ， 在 查询 结果 中 ， 用 户 仅 需 其 中 的 一 部 分 记录 ， 这 时 就 需要 使 用 where 子 句 指定 一 系列 的 查询 条 件 。 
下 面 是 where 子 句 最 简单 的 语法 : 

SELECT< 字 段 列 表 > 

FROM< 表 名 > 

WHERE< 条 件 表达 式 > 

为 了 满足 多 种 不 同 的 查询 ，where 子 句 提供 了 丰富 的 搜索 条 件 ， 下 面 给 出 where 子 句 常用 的 比较 运算 符 ， 如 
表 8.1 所 示 。 


图 8.28 指定 删除 id 等 于 5 的 数据 


表 8.1 where 子 句 常用 的 比较 运算 符 


运 算 符 说 有明 
= 等 于 
> 大 于 
< 小 于 
和 大 于 等 于 
< 小 于 等 于 
> 不 大 于 
< 不 小 于 
一 或 = 不 等 于 
图 设计 过 程 
(1) 开启 MySQL 服务 ， 输 入 命令 连接 MySQL 服务 器 ,创建 数 
据 库 和 数据 表 ， 将 数据 表 命 名 为 tb_mrbook， 并 通过 insert 语句 向 数 
据 表 里 添 加 信息 ， 通 过 select 语句 查看 表 信息 。 
(2) 通过 delete 语句 删除 id 等 于 5 的 数据 ， 运 行 结果 如 图 8.29 图 8.29 删除 成 功 提示 
所 示 。 
国 秘笈 心 法 


心 法 领悟 361: where 子 句 的 优点 。 
where 子 句 是 非常 灵活 的 ， 其 使 用 方法 与 PHP 中 的 站 语句 有 些 类 似 ， 也 可 以 用 于 执行 比较 或 逻辑 运算 。 
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8.5 PHP 操作 MySQL 数据 库 


PHP 支持 的 数据 库 类 型 较 多 ， 在 这 些 数据 库 中 ，MySQL 数据 库 与 PHP 结合 最 好 ， 与 Linux 系统 、Apache 
服务 器 和 PHP 语言 构成 当今 主流 的 LAMP 网 站 架构 模式 ， 并 且 PHP 提供 多 种 操作 MySQL 数据 库 的 方式 ， 因 
而 适合 不 同 需 求 和 不 同类 型 项 目的 需要 。 


力 实例 说 明 


通过 PHP 语言 连接 MySQL 数据 库 与 在 cmd 命令 提示 符 下 操作 数据 库 有 所 不 同 。 例 如 ， 设 置 页 面 的 编码 格 
式 为 GBK, 在 MySQL 命令 提示 符 下 只 需 输 入 set names gbk 即 可 ,而 在 PHP 中 需 使 用 函数 mysql_query("set names 
GBK") 实 现 。 所 以 在 学 习 操 作 MySQL 数据 库 的 同时 还 要 与 PHP 函数 联合 应 用 ， 下 面 就 来 讲解 使 用 PHP 操作 
MySQL 数据 库 。 本 实例 通过 mysql_connect0 函 数 连 接 MySQL 服务 器 ， 运 行 结果 如 图 8.30 所 示 。 


连接 MySQL 服 务 器 


‘aosr [ocahoct ‘mer [oot ry 到 


高 级 


| 
上 
超时 可: 机 


8.30 连接 MySQL 服务 器 


图 关键 技术 
使 用 mysql_connect0 函 数 打开 一 个 到 MySQL 服务 器 的 连接 ， 其 语法 如 下 : 


esolroe mysql conneet ( [string server [, sring vseriame [, string peseword [, bool new Hink [, int elient Alags]]ll]); 
参数 说 明 : 

string server: 表示 连接 数据 库 的 HOST。 

string username: 表示 MySQL 数据 库 用 户 名 。 

string password: 表示 MySQL 数据 库 密码 。 


图 设计 过 程 
新 建 index.php 文件 ， 创 建 form 表单 提交 连接 MySQL 服务 器 的 用 户 名 、 密 码 和 服务 器 。 获 取 form 表单 提 
交 的 数据 ， 应 用 mysql_connectO 函 数 完成 与 MySQL 服务 器 的 连接 ， 其 代码 如 下 : 


<2php 
if($_POST[sub){ // 单 击 “ 确 定 ” 按 钮 
if($_POST[na] —""||$_POST[nam] 一 "||$_ POST[name] —""){ /检测 文本 框 是 否 为 空 
echo "<script>alert(' 文 本 框 不 能 为 空 '):</script>"; /输出 提示 
Jelse{ 
if(@mysql_connect("$_POST[na]"."”$_POST[nam]"."$_POST[name]"){ // 连 接 MySQL 服务 器 
echo "<script>alert( 连 接 MySQL 服务 器 成 功 ):</script>": /输出 提示 


jelsef 
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echo "<script>alert( 错 误 了 ");</script>"; 
> 
} 
} 


> 


国 秘笈 心 ; 


心 法 领悟 362: 连接 MySQL 服务 器 。 
安装 MySQL 数据 库 时 ， 会 提示 用 户 设置 Host、 用 户 名 和 密码 。 如 果 用 户 并 未 进行 设置 ，MySQL 在 默认 安 
装 的 情况 下 ，Host 为 localhost、 用 户 名 为 root、 密 码 为 NULL ( 空 ) 。 


趣味 指数 : | 


实例 363 


图 实例 说 明 

通过 函数 mysql_connect0 可 以 与 MySQL 服务 器 建立 连接 ， 在 cmd 命令 提示 符 下 使 用 use 语句 选择 想 要 操 
作 的 数据 库 。 在 PHP 代码 中 需要 使 用 mysql_select_db0 函 数 选择 并 连接 数据 库 。 本 实例 通过 mysql_select_db() 
函数 实现 与 MySQL 数据 库 的 选择 全 全 运行 结果 如 图 8.31 所 示 。 


图 8.31 使 用 函数 选择 并 连接 MySQL 数据 库 


力 关键 技术 


Imysql_ select db0 函 数 用 于 选择 MySQL 数据 库 ， 其 语法 如 下 : 


te 
参数 说 明 : 

string database_name: 表示 选择 MySQL 数据 库 名 称 。 
resource link_identifier: 表示 MySQL 连接 标识 。 


图 设计 过 程 
(1) 新 建 index.php 文件 。 首 先 连接 MySQL 服务 器 ， 通 过 mysql 函数 库 的 函数 读 取 输 出 MySQL 数据 库 中 
存储 的 数据 库 名 称 ， 并 且 通 过 下 拉 列 表 框 显示 所 有 数据 库 名 称 ， 代 码 如 下 : 


<?php 


Sconn = mysql_connect("localhost", "root","111"): /连接 MySQL 服务 器 
Srs = mysql_query("show databases"); /查询 操作 
while($rst = mysql_fetch_array($rs){ //while 循环 
$a=0; 
echo "<option value=".$rst[$a].">".S$rst[$a]."</option><br>"; /输出 数据 库 名 称 
Satt; 
} 
2> 


(2) 当 单 击 “确定 ”按钮 时 ， 将 下 拉 列 表 框 的 选择 信息 以 参数 的 形式 传递 给 mysql select db0 函 数 ， 并 输 
出 提示 信息 ， 其 代码 如 下 : 
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hp 
if($_POST[sub){ // 通 过 POST 方式 传递 参数 
if($_POST[select] — "1"){ // 当 下 拉 列 表 框 值 为 1 时 
echo "<script>alert(' 请 选择 数据 库 );</script>"; // 输 出 提示 信息 
jelsef 
if(mysql_select_db("$_POST[select]".$Sconn){ // 如 果 不 为 1， 连接 数据 库 
mysql_close(); /关闭 连接 
echo "<script>alert(' 已 选择 指定 数据 库 ");</script>"; /输出 提示 
Jelse{ 
echo "<script>alert( 出 错误 了 人 );</script>"; // 提 示 信 息 
} 
us 
} 
> 
秘笈 心 法 


心 法 领悟 363: 两 种 方法 判断 数据 库 是 否 连 接 成 功 。 

本 实例 是 利用 mysql_select_db0 函 数 的 返回 值 ， 判 断 是 否 连 接 到 数据 库 从 而 输出 提示 信息 。 还 可 以 通过 
mysql_select_db0 or dieO 函 数 来 判断 是 否 连 接 到 数据 库 ， 如 果 连 接 到 数据 库 将 不 会 有 任何 信息 提示 , 否则 输出 错误 
信息 。 


高 级 | 


趣味 指数 : 克 友 友 克 | 


实例 364 


实例 说 明 


用 PHP 代码 操作 MySQL 数据 库 的 主要 目的 是 为 了 让 程序 控制 数据 库 信 息 的 增删 改 查 等 操作 ， 而 函数 
mysql_query0 可 以 看 作 是 部 分 SQL 语句 的 载体 。 本 实例 通过 mysql_query0 函 数 执 行 SQL 语句 ， 运 行 结 果 如 
图 8.32 所 示 。 


图 8.32 mysql query0 函 数 执行 SQL 语句 


力 关键 技术 


使 用 mysql_query0 函 数 ， 可 向 与 指定 的 连接 标识 符 关 联 的 服务 器 中 当前 活动 的 数据 库 发 送 一 条 MySQL 查 
询 ， 其 语法 如 下 : 

‘resource mysql_query ( string query [, resource link identifier] ); 

参数 说 明 : 

resource link_identifier: 连接 标识 。 

string query: SQL 语句 。 


图 设计 过 程 
新 建 index.php 文件 。 首 先 连 接 服务 器 ， 连 接 db_database08 数据 库 。 然 后 获取 form 表单 中 提交 的 SQL 语 
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句 , 并 且 对 SQL 语句 的 类 型 进行 判断 , 根据 不 同 的 类 型 应 用 mysql_query0 函 数 执行 不 同 的 操作 , 其 关键 代码 如 下 : 
if($_POST[sub){ / 单 击 按钮 


$sql =$_POST[text]: /定义 变量 
ifSsql 一 "9){ /如 果 文 本 框 为 空 
echo "<scriptf>alert( 您 输入 的 文本 框 内 容 为 空 );</lscript>": //JavaScript 提示 
jslsef 
Sconn = mysql_connect("localhost","root","111") or die(" 连 接 MySQL 出 现 错误 "); 。“”// 连 接 MySQL 
mysql_select_db("db_database08",$conn) or die("false"): // 连 接 数据 库 
$sqll = substr($sql.0.6): 1/ 截取 SQL 语句 前 6 个 字符 
if(strtoupper($sqll) 一 "SELECT"){ 
这 mysql_query(SsqD){ /| 执行 查询 操作 
echo "<script>alert( 您 在 执行 查询 操作 ");</script>"; 
Jelse{ 


echo "<script>alert(SQL 语句 出 现 错误 ));</script>"; 


} 
jelsef 
if(strtoupper($sqll) — "INSERT"){ 
这 mysql query($sqD)f 
echo "<script>alert( 您 在 执行 插入 操作 );</script>"; 
jelse{ 
echo "<script>alert('SQL 语句 出 现 错误 ):</script>": 


| 
jelsef 
这 strtoupper($sql1) — "UPDATE"){ 
这 mysql_query(SsqD){ 
echo "<script>alert(' 您 在 更 新 查询 操作 '):</seript>"; 
Jelse{ 
echo "<script>alert('SQL 语句 出 现 错误 );</script>"; 
} 


} 


> 
在 对 SQL 语句 的 类 型 进行 判断 时 ， 首 先 应 用 substr0 函 数 截取 SQL 语句 的 前 6 个 字 节 ， 然 后 将 截取 的 内 容 
转换 为 小 写 ， 并 通过 这 6 个 字符 串 对 SQL 语句 的 类 型 进行 判断 。 


力 秘笈 心 法 
心 法 领悟 364: mysql_query0 函 数 中 连接 标识 符 的 作用 。 
mysql_query0 函 数 向 与 指定 的 连接 标识 符 关 联 的 服务 器 中 当前 活动 的 数据 库 发 送 一 条 查询 。 如 果 没 有 指定 


link_identifier， 则 使 用 上 一 个 打开 的 连接 ， 如 果 没 有 打开 的 连接 ， 该 函数 会 尝试 无 参数 调用 mysql_connect0 函 
数 来 建立 一 个 连接 并 使 用 ， 其 查询 结果 会 被 缓存 。 


y() 函 数 将 结果 返回 到 数组 中 


实例 365 


力 实例 说 明 


用 户 在 进行 查询 操作 时 ， 目 的 是 为 了 将 结果 显示 到 网 页 中 ， 下 面 介绍 如 何 通过 mysql_fetch_array0 函 数 将 查 
询 结果 返回 到 数组 中 。 本 实例 通过 函数 mysql_fetch_array0 将 查询 结果 返回 到 数组 中 ， 打 印 数组 的 结果 如 图 8.33 
所 示 ， 循 环 输出 数组 中 数据 的 结果 如 图 8.34 所 示 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


mysqlfectch-arra70 画 堵 


a 全 各 不 过 二 3R 于 


[0] 
7 1 ) 
array ([0]=> 3 [四 ] => 3 [1] => 小 淆 [namne] => 小 洒 [2]=> 1026 [pwd] 
17- 
[0] 


Do 
1 明日 科技 mrsoft 2010-07-13 
3 [last_date] => 2010-07-13 ) 2 小 杨 1081 2010-07-13 
3 
4 


小 少 1026 2010-07. 
小 刘 1015 2010-07-13 


=> 4 [四 ]=> 4 [1] => 小 齐 [name] => 小 刻 [2]=> 1015 [pwd] => 1015 [ 习 =>| 
2010-07-13 [last_date] => 2010-07-13 ) 


图 8.33 打印 数组 图 8.34 打印 表格 


图 关键 技术 
mysql fetch_array0 函 数 用 于 从 结果 集中 取得 一 行 作为 关联 数组 或 数字 数组 ， 或 二 者 兼 有 ， 其 语法 如 下 ; 


array mysql_fetch_array ( resource result [, int result_type] ); 
参数 resource result 为 结果 集 。 


图 设计 过 程 
(1) 创建 PHP 脚本 文件 ， 命 名 为 in.php， 将 MySQL 数据 库 的 连接 操作 封装 到 类 中 ， 定 义 构造 函数 为 成 员 
变量 赋值 ， 定 义 connect0 函 数 实 现 与 MySQL 服务 器 和 数据 库 的 连接 。mysql 类 的 代码 如 下 : 


<?php 
class mysql{ 
var $conn; 
var $host; 
var $username; 
var $pwd: 
var $db; 
function __construct($host,Susemame, S$pwd,$db){ // 为 成 员 变 量 赋值 
Sthis -> host = $host: 
Sthis -> usermame = $usemame; 
Sthis -> pwd = Spwd: 
Sthis -> db = $db; 
Sthis -> connect(); 


a connectO{ 
Sthis -> conn = $conn; // 定 义 连接 标识 
Sthis -> conn = mysql_connect($this -> host,$this -> usemame.S$this -> pwd); // 连 接 数据 库 服务 器 
mysql_select_db($this -> db,S$this -> conn); // 连 接 数据 库 
mysql_query("SET NAMES UTF8"); 1/ 设置 数据 库 编码 
} 
} 


?> 

(2) 创建 PHP 脚本 文件 ， 命 名 为 index.php。 首 先 ， 包 含 数 据 库 连 接 类 文件 。 然 后 ， 执 行 类 的 实例 化 操作 ， 
完成 与 数据 库 的 连接 ， 并 返回 连接 对 象 。 最 后 ， 定 义 SQL 查询 语句 ， 通 过 mysql_ query0 函 数 执行 查询 操作 ， 通 
过 mysql fetch_array() 函 数 将 查询 结果 集 存储 到 数组 中 ， 并 通过 while 语句 循环 输出 查询 结果 集中 的 数据 ， 其 代 


码 如 下 : 

<?php 

if($_GET[amra] — "1"){ // 如 果 地 址 栏 参 数 arra 等 于 1 
include("in.php"): // 包 含 数据 库 连 接 类 
Smy = new mysql("localhost","root"."111"."db_database08"); // 实 例 化 数据 库 连接 类 
$sql = "select * from tb_020"; JWsaQL 语句 
Srs = mysql_query($sqD: // 执 行 查询 操作 并 返回 结果 集 
while(Srst= mysql_fetch_array(Srs)){ /循环 数组 

Print_r($rst); /打印 数组 
} 
if($_GET[table] — "1"){ // 如 果 地 址 栏 参数 table 等 于 1 
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include("in.php"); // 包 含 数据 库 连接 类 
Smy = new mysql("localhost"."root","111"."db_database08"); /实例 化 对 象 
$sql = "select * from tb_020"; //SQL 语句 
Srs = mysql_ query($sqD; // 返 回 结果 集 
9 
<table border="1" bordercolor="#FFCC00" cellspacing="Opx" width="580px"> 
<tr><td>ID</td><td> 用 户 名 </td><td> 密 码 </td><td> 时 间 <Jtd></tr> 
hp 
while($rst = mysql_fetch_array($rs){ 1/ 循环 数组 
echo "<tr>"; 
echo "<td>".$rst[0]."</td><td>".$rst[1]."</td><td>".$rst[2]."</td><td>".$rst[3]."</td>"; // 表 格式 输出 
echo "</tr>"; 
: 
> 
</table> 
php 
} 
> 
二 
力 秘笈 心 法 


心 法 领悟 365: 使 用 mysql_fetch_array0 函 数 的 注意 事项 。 
在 使 用 mysql_fetch_array0 函 数 时 ， 如 果 结 果 中 的 两 个 或 以 上 的 列 具 有 相同 字段 名 ， 最 后 一 列 将 优先 。 要 访 
问 同名 的 其 他 列 ， 必 须 用 该 列 的 数字 索引 或 给 该 列 起 个 别名 ， 对 有 别名 的 列 不 能 再 用 原来 的 列 名 访问 其 内 容 。 


防 数 从 结果 集中 获取 数据 高 级 | 


趣味 指数 : holoiodl 


实例 366 


图 实例 说 明 
获取 查询 结果 集中 数据 信息 的 函数 很 多 ， 下 面 推荐 一 个 新 的 获取 结果 集中 数据 的 函数 一 mysql_fetch_row0。 
本 实例 的 运行 结果 如 图 8.35 所 示 。 


mysql fetch row() 四 诸 - w 
从 结 黑 咎 中 获取 数据 


查 询 下 = 条 
ID 用 请 名 E23 是 问 
小 惕 1081 2010-07-14 


图 8.35 查询 一 条 数据 


力 关键 技术 


mysql_fetch_row0 函 数 用 于 从 结果 集中 获取 一 行 作为 枚 举 数组 , 返回 根据 所 获取 的 行 生成 的 数组 , 如 果 没 有 
更 多 行 则 返回 FALSE， 其 语法 如 下 : 


amray mysql_fetch_row ( resource result ); 


参数 result 为 指定 的 结果 集 。 
看 设计 过 程 
(1) 新 建 in.php 文件 ， 封 装 数据 库 的 连接 类 。 
(2) 新 建 mdex.php 文件 。 首 先 包 含 数据 库 连 接 类 文件 ， 然 后 执行 类 的 实例 化 操作 ， 完 成 与 数据 库 的 连接 


并 返回 连接 对 象 ， 最 后 通过 mysql fetch rowO 函 数 将 查询 结果 集 存 储 到 数组 中 ， 并 输出 获取 到 的 数据 ， 其 代码 
如 下 : 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


include (vin.php"): 
Smy = new mysql ( "localhost", "root", "111", "db_database08" ): 
Hf($_GET [id]—1){ 
$sql = "select * from tb_demo021"; 
Srs =mysql_query ($sql ): 
Srst =mysql fetch_row ( Srs ); 
?> 
<aphp 
echo "<tr><td class='one>" . Srst [0] . "</td><td class=one>" . Srst [1] . "</td><td class=one>" . Srst [2] . "</td><td class=one>" .Srst [3] . 
"</td></tr>"; 


} 
/| 单 击 “ 下 一 条 ”按钮 ， 类 似 分 页 
if($_GET [id] =—2) { 
$os = mysql_query ("select * from tb_demo021_order order by id desc limit 1" );: 
Sost = mysql fetch_row ( $0s ); 
Sid = Sost [1]: 
S$rs = mysql_ query ( "select * from tb_demo021 limit $id.1" ); 
Sid=$id+ 1; 
Srst = mysql fetch row (Srs); 
?> 


国 秘笈 心 法 


心 法 领悟 366:; mysql_fetch_row0 函 数 的 特点 。 

mysql_fetch_row0 函 数 是 从 指定 的 结果 标识 关联 的 结果 集中 取得 一 行 数据 并 作为 数组 返回 ,每 个 结果 的 列 存 
储 在 一 个 数组 的 单元 中 ， 偏 移 量 从 0 开始 。 依次 调用 mysql fetch_row0 函 数 将 返回 结果 集中 的 下 一 行 ， 如 果 
没有 更 多 行 则 返回 FALSE。 


力 实例 说 明 


本 实例 介绍 如 何 通过 PHP 的 函数 mysql_ num_rows0 统 计数 据 库 中 的 记录 数 ， 运 行 结果 如 图 8.36 所 示 。 


函数 获取 结果 集中 记录 数 高 级 | 


趣味 指数 : 傅 傅 银 良 | 


当前 共有 数据 夫 个 


8.36 tb demo021 下 的 信息 数量 


看 关键 技术 
mysql_num rows0 函 数 用 于 取得 结果 集中 行 的 数目 ， 其 语法 如 下 : 


int mysql_num rows ( resource result ); 


参数 result 指定 操作 的 结果 集 ， 其 返回 值 为 int 类 型 。 
力 设计 过 程 
(1) 新 建 n.php 文件 ， 封 装 数据 库 的 连接 类 。 
(2) 新 建 index.php 文件 。 首 先 包 含 数据 库 连接 类 文件 ， 然 后 执行 类 的 实例 化 操作 ， 完 成 与 数据 库 的 连接 
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并 返回 连接 对 象 ， 最 后 通过 mysql num rows0 函 数 统计 数据 库 、 数 据 表 的 个 数 以 及 指定 数据 表 的 总 记录 数 ， 其 
关键 代码 如 下 : 
<Iphp 
include ("in.php"): 
Smy =new mysql ( "localhost", "root", "111", "db_database08" ): 
if($ GETIid] = Df 
Srs =mysql_query ( "show databases" ); 
Snum = mysql_num rows ( $rs ): 
while ( S$rst= mysql fetch row (Ses)){ 
Print r ( Srst ); 


echo "<br><b class='two> 当 前 共有 数据 库 <b class=three>" . Snum . "</b> 个 <lb>"; 
} 
上 述 代 码 查 询 MySQL 数据 库 中 包含 的 数据 库 ， 通 过 mysql_ num rows0) 函 数 统计 数据 库 的 个 数 ， 应 用 while 
语句 循环 输出 数据 库 的 名 称 。 
秘笈 心 法 
心 法 领悟 367: 使 用 mysql_ num rows0 函 数 的 注意 事项 。 
mysql_num_rowsO 函 数 仅 对 select 查询 语句 有 效 。 


} 


实例 368 级 到 


起 味 指数， 诬 亦 太 
力 实例 说 明 


如 果 想 要 查看 数据 表 中 某 个 单元 的 数据 ， 那 么 推荐 使 用 mysql_result0 函 数 。 本 实例 将 介绍 如 何 使 用 
mysql_ resultO) 函 数 获取 结果 集中 指定 单元 的 数据 ， 运 行 结果 如 图 8.37 所 示 。 


mysql result()(D 


8.37 取得 一 条 字段 


图 关键 技术 
Imysql resultO 函 数 用 于 返回 MySQL ic lm ed 其 语法 如 下 : 


mixed mysql result ( resource result, int row [. mixed field] 
参数 说 明 : 

resource result: 结果 集 。 

int row: 行 数 。 

mixed field: 可 选 参数 ， 字 段 名 称 。 


力 设计 过 程 
(1) 创建 脚本 文件 命名 为 mn.php， 利 用 面向 对 象 知识 编写 数据 库 连接 类 。 


PHP 开发 实例 大 全 (基础 卷 ) 


(2) 创建 脚本 文件 ， 命 名 为 index.php。 首 先 包 含 数据 库 连接 类 ， 对 类 进行 实例 化 ， 连 接 数 据 库 ， 然 后 通 
过 while 语句 和 mysql_fetch_ row0 函 数 循 环 输出 数据 表 中 数据 ， 最 后 根据 form 表单 提交 的 数据 进行 判断 ， 在 


switch 语句 中 通过 mysql_result0 函 数 获取 数据 表 中 指定 单元 的 数据 ， 其 关键 代码 如 下 : 
<?php 


} 
if($_POST[sub) { /1/ 判 断 提交 按钮 的 值 是 否 为 真 
if ol 1||$_POST[name] < D{ 
"<script>alert( 选 择 的 是 表格 表 头 ):</script>"; 
Se 


switch($_POST[na]){ /在 switch 语句 中 ， 根 据 表单 提交 的 值 进行 判断 
case "ID": 
Srse = mysql_result($rs.$_POST[name]-1."id"); // 获 取 指 定单 元 的 数据 
echo "取得 字段 为 ".Srse; 
break; 
case "用 户 ": 
Srse = mysql_result($rs,$_POST[name]-1,"name"); 
echo "取得 字段 为 ".Srse; 


break; 

case "密码 ": 

Srse= mysql Snes POST[name]-1,"pwd"); 
echo a 


case ee 
Srse =mysql s es POST[name]-1,"date"); 
echo "取得 字段 
break; 
了 
} 


} 
?> 


国 秘笈 心 法 


心 法 领悟 368: 使 用 mysql_result0 函 数 的 注意 事项 。 
当 mysql_result() 函 数 作用 于 很 大 的 结果 集 时 ， 应 该 考虑 使 用 能 够 取得 整 行 的 函数 。 这 些 函数 在 一 次 函数 调 
用 中 返回 多 个 单元 的 内 容 ， 效 率 高 于 mysql_result0 函 数 。 


ii 一 
| 


实例 369 区 全 让 真人 丰 


力 实例 说 明 


MySQL 数据 库 的 主要 作用 在 于 能 够 存储 大 量 的 数据 ， 作 为 数据 的 规范 化 载体 ,可 以 通过 INSERT 添加 语句 
将 数据 添加 到 数据 表 中 。 本 实例 通过 INSERT 语句 向 图 书信 息 表 中 添加 信息 ， 运 行 结 果 如 图 8.38 所 示 。 


INSERT 语 名流 加 人 @ 书 


8.38 插入 数据 
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力 关键 技术 
INSERT 语句 用 于 向 数据 库 插入 一 条 数据 ， 语 法 如 下 : 


INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] 
[INTO] tbl_name [(eol_name...)] 
VALUES ({expr | DEFAULT}...).(..),... 
[ON DUPLICATE KEY UPDATE col_ name=expr, ... ] 


本 实例 中 实现 添加 图 书信 息 的 SQL 语句 如 下 : 
$sql = "insert into tb_demo024(id,name.pwd.date)values(","$_POST[n]','$_POST[na]',$_POST[nam])": 
图 设计 过 程 
(1) 建立 inphp 文件 ， 编 写 MySQL 数据 库 的 连接 类 。 
(2) 编写 index.php 文件 ， 创 建 form 表单 ， 提 交 要 添加 的 图 书信 息 ， 将 数据 提交 到 本 页 。 获 取 表单 中 提交 


的 数据 ， 连 接 数据 库 ， 通 过 INSERT 语句 将 表单 提交 的 数据 添加 到 指定 的 数据 表 中 ， 最 终 循环 输出 数据 表 中 的 
数据 ， 其 关键 代码 如 下 : 


if($_POST[sub2D){ 
if($_POST[n] = "" ||$_POST[na] = ""||$_POST[nam] {= ""){ // 判 断 提交 的 数据 是 否 为 空 
iflpreg_match("/\d/",$_POST[na]){ // 通 过 正则 表达 式 判 断 提交 数据 格式 是 否 正确 
$sql = "insert into tb_demo024(id.name.pwd.date)values(",'$_POST[n]'$_POST[na]''$_POST[nam])"; 
if(mysql_query($sqD){ /| 执行 添加 语句 


echo "<script>alert(' 插 入 数据 成 功 ):location href='index php?id=3';</script>"; 
} 
es 
} 
jelsef 
echo "<script>alert( 文 本 框 为 空 );</script>"; 
} 
图 秘笈 心 ; 
心 法 领悟 369: 使 用 INSERT 语句 的 注意 事项 。 
在 PHP 中 ， 通 过 INSERT 语句 向 数据 表 中 添加 数据 时 ， 要 做 到 三 点 统一 : 
(1) form 表单 中 定义 的 表单 元 素 名 称 与 在 数据 处 理 页 中 通过 $_POST 方法 获取 表单 元 素 值 使 用 的 名 称 统 
一 ， 同 时 还 要 注意 它们 是 区 分 字符 大 小 写 的 。 如 果 两 个 名 称 不 统一 ， 那 么 将 获取 不 到 指定 的 值 。 


(2) 在 编辑 的 INSERT 添加 语句 中 ， 字 段 的 名 称 与 字段 的 值 必须 对 应 ， 不 能 将 varchar 类 型 的 数据 添加 到 
date 类 型 的 字段 中 。 


(3) 在 编辑 的 INSERT 添加 语句 中 ,字段 的 名 称 必须 与 数据 表 中 定义 的 字段 名 称 统一 ， 否 则 同样 会 导致 添 
加 失败 。 


图 书信 息 高 级 | 
实例 370 趣味 指数 : 让 丰 三 碍 | 


0 
国 实例 说 明 


数据 库 可 以 与 PHP 页 面 进行 很 好 的 交互 ， 既 可 以 向 数据 库 中 插入 数据 ， 也 同样 可 以 从 数据 库 中 查询 数据 。 
本 实例 通过 SELECT 语句 实现 查询 图 书信 息 ， 运 行 结果 如 图 8.39 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


SELEGT 语 名 要 询 四 书信 息 


图 8.39 查询 图 书信 息 


图 关键 技术 


SELECT 语句 是 在 SQL 中 比较 常用 的 语句 ， 也 是 比较 重要 的 语句 。 使 用 SELECT 语句 可 以 从 数据 表 或 视图 
中 进行 查询 ， 并 将 查询 结果 以 表格 的 形式 返回 ， 以 表格 返回 的 结果 也 可 以 称 为 结果 集 。SELECT 语句 中 的 主要 
结构 如 下 : 


SELECT select list 

[INTO new_table name] 

FROM table_ list 

[ WHERE search_conditions] 

[ GROUP BY group_by list] 
[HAVING search_conditions] 
[ORDER BY order list [ASC| DESC ]] 


参数 说 明 : 

select list: 指定 需要 查询 返回 的 列 。 多 个 列表 之 间 使 用 逗号 分 隔 。 在 选择 列表 时 也 可 以 使 用 “*” 符 号 来 表 
示 返 回 表 中 的 所 有 列 。 

INTO new _table_ name: 创建 新 表 并 将 查询 行 插入 新 表 中 。new_table_name 指定 新 表 的 名 称 。 

FROM table_list; 指定 需要 查询 的 表 。 这 些 来 源 表 可 能 包括 基 表 、 视 图 和 链接 表 。FROM 子 句 还 可 包含 连 
接 说 明 ， 该 说 明定 义 了 SQL Server 用 来 在 表 之 间 进 行 导航 的 特定 路 径 。 

WHERE search_conditions: WHERE 子 句 指定 用 于 限制 返回 行 的 搜索 条 件 。 

GROUP BY group_by_list: GROUP BY 子 句 根据 group_by_list 列 中 的 值 将 结果 集 分 成 组 ,例如 , student 表 
在 “性别 ” 中 有 两 个 值 。GROUP BY ShipVia 子 句 将 结果 集 分 成 两 组 ， 每 组 对 应 于 ShipVia 的 一 个 值 。 

HAVING search_conditions: HAVING 子 句 指定 组 或 聚合 的 搜索 条 件 。 逻 辑 上 讲 ，HAVING 子 句 从 中 间 结 
果 集 对 行进 行 筛 选 ， 这 些 中 间 结 果 集 是 用 SELECT 语句 中 的 FROM、WHERE 或 GROUP BY 子 句 创建 的 。 
HAVING 子 句 通常 与 GROUP BY 子 句 一 起 使 用 ， 尽 管 HAVING 子 句 前 面 不 必 有 GROUP BY 子 句 。 

ORDER BY order list [ ASC | DESC ]: ORDER BY 子 句 定义 结果 集中 的 行 排列 的 顺序 。order_list 指定 组 成 
排序 列表 的 结果 集 的 列 。ASC 和 DESC 关键 字 用 于 指定 行 是 按 升 序 还 是 降序 排序 。ORDER BY 之 所 以 重要 ， 
是 因为 其 关系 理论 规定 除非 已 经 指定 ORDER BY, 否则 不 能 假设 结果 集中 的 行 带 有 任何 序列 。 如果 结果 集中 行 
的 顺序 对 于 SELECT 语句 来 说 很 重要 ， 那 么 在 该 语句 中 就 必须 使 用 ORDER BY 子 句 。 


图 设计 过 程 
(1) 建立 inphp 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连接 类 。 


(2) 编写 index.php 文件 ， 包 含 数据 库 连 接 类 ， 实 例 化 对 象 ， 连 接 数 据 库 。 然 后 执行 查询 语句 ， 通 过 while 
语句 和 mysql_fetch_rowO 函 数 循环 输出 查询 结果 ， 核 心 代码 如 下 : 
<?php 


include("in.php"): // 包 含 数据 库 连 接 类 

new mysql("localhost","root","111","db_database08"):; // 实 例 化 对 象 

if($_GET[id] =— D{ /如 果 地 址 栏 参 数 记 等 于 1 
Srs = mysql_query("select * from tb_demo025"): /返回 结果 集 
echo "<table width='580px>": /输出 结果 


echo "<tr><td style=color 考 FFFFF>ID<ltd><td bgcolo 一 上 FFFFF> 书 名 </td><td style='color 红 FFFFF> 价 格 </td><td 
bgcolor=#FFFFFF> 日 期 </td></tr>"; 
while($rst = mysql_ fetch_row($rs){ 
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echo "<tr><td >".$rst[0]."</td><td bgcolor=#FFFFFF'>".$rst[1]."</td><td >".$rst[2]."</td><td>".$rst[3]."</td></tr>"; 
} 
echo "</table>": 
} 


?> 


心 法 领悟 370: SELECT 语句 的 优点 。 
灵活 运用 SELECT 语句 可 以 编写 出 非常 复杂 的 查询 ， 如 单列 查询 、 多 列 查询 、 查 询 所 有 列 、 别 名 的 应 用 、 
TOP 查询 前 若干 行 、 计 算 列 查询 、 条 件 查询 和 范围 查询 等 。 


nn ， 

ch 高 级 : 
起 味 指数 : 贾 页 页 页 | 
图 实例 说 明 


SELECT 语句 可 以 查询 数据 库 信息 ， 但 是 如 果 数 据 库 信息 非常 多 ， 在 一 个 页 面 中 显示 所 有 数据 ， 首 先 会 使 
页 面 显得 繁杂 、 不 美观 ， 其 次 会 给 用 户 造成 网 站 不 够 智能 的 表象 。 本 实例 灵活 运用 SELECT 语句 实现 对 图 书信 
息 的 分 页 处 理 ， 其 运行 结果 如 图 8.40 所 示 。 


LR Tn 
wD 韦 名 日 其 


6 《C4 万 提交 由 宝 要 》 75 元 2010-07-16 
7 《rr 开发 实 赋 裤 半 了 75 元 2010-07-16 
a 《PHP 范 全 宝典》 6 元 2010-07-16 
9 《VBE 诉 宇 闪 》 区 元 2010-07-16 


10 《Java 苑 全 衬 雁 》 76 元 2010-07-16 


8.40 ”分 页 显示 图 书信 息 


图 关键 技术 


本 实例 应 用 SELECT 查询 语句 及 其 子 句 limit， 实 现 图 书信 息 的 分 页 显示 。 通 过 limit 关键 字 控 制 当前 页 面 
显示 的 记录 数 和 开始 位 置 。 本 实例 分 页 查询 图 书信 息 的 SQL 语句 代码 如 下 : 


$sql = "select + from tb_demo026 limit "((Spage - 1)*$num).",". Snum: 


其 中 (($page - D*Snum) 计 算 的 是 当前 页 的 开始 位 置 ， 而 Snum 是 当前 页 显示 的 记录 数 。 
力 设计 过 程 
(1) 建立 in.php 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连接 类 。 
(2) 编写 index.php 文件 。 首 先 包 含 数据 库 连接 类 并 实例 化 对 象 ， 然 后 定义 查询 语句 统计 查询 结果 集中 的 


记录 数 ， 定 义 分 页 变量 ， 接 着 定义 分 页 查询 语句 ， 每 页 显示 5 条 记录 ， 最 后 创建 分 页 超 链接 ， 完 成 图 书信 息 的 
分 页 显示 ， 核 心 代码 如 下 : 
<2php 


include("in.php"); // 包 含 数据 库 连 接 类 
new mysql("localhost","root","111"."db_database08"): 1/ 实例 化 对 象 
if($_GET[id] =— D{ // 如 果 地 址 栏 参 数 等 于 1 
Snum = 5: /定义 变量 
Srse = mysql_query("select * from tb_demo026"); // 执 行 查询 操作 
Snu = mysql_num_rows(Srse): /返回 数据 库 信息 条 数 
这 !$_GET[page]){ /设置 地 址 栏 参数 page 
Spage = 1; 


PHP 开发 实例 大 全 (基础 卷 ) 


Jelse{ 
Spage =$_GET[page]; 
$sql = "select * from tb_demo026 limit ".(($page - 1)*$num).".".Snum:; // 分 页 SQL 语句 
Srs = mysql_ query($sq]): // 返 回 结果 集 
Snur = ceil($nu/$num): / 取 整 函数 
echo "<a hre 人 index .php?id=1&page=1> 首 页 </a>": /设置 主页 地 址 栏 参数 
这 $page >— 2){ // 如 果 地 址 栏 参数 page 值 大 于 等 于 2 
?> 
<a href="index.php?id=1 &page=<?php echo $page-1:?>"> 上 一 页 </a> /上 一 页 
<?php 
上 
if($page < $nur){ // 如 果 page 小 于 总 页 数 
?> 
<a href="index.php?id=1&page=<?php echo $page+l:?>"> 下 一 页 </a> 。 /下 一 页 
<?php 
} 
?> 
<a href="index.php?id=1&page=<?php echo $nur:?>"> 尾 页 </a> // 尾 页 
<?php 


echo "<table width="580px'><tr><td width="100px' bgeolor=#FFFFFF'>ID</td><td width= 200px> 书 名 <htd><td width= 180px' 
bgcolor=#FFFFFF> 价 格 </td><td width='100px> 日 期 </td></tr>"; 
while($rst = mysql_feteh_row($rs)){ 
echo "<tr><td bgcolor=#FFFFFF">".$rst[0]."</td><td> (".$rst[1].")》 </td><td bgeolor=#FFFFFF>".$rst[2]."</td><td>".$rst[3]."</td></tr>"; 


| 
echo "</table>"; 
} 


2> 


图 秘笈 心 法 
心 法 领悟 371: SELECT 语句 的 子 句 limit。 


SELECT 语句 的 子 句 limit 功能 很 强大 ， 可 用 于 控制 查询 语句 的 开始 位 置 以 及 查询 的 数量 ， 但 是 limit 子 名 
是 MySQL 数据 库 特 有 的 ， 在 SQL Server 或 者 Access 数据 库 中 是 不 支持 的 。 


a 高 级 | 
实例 372 趣味 指数 : obololodl 
图 实例 说 明 


程序 员 在 手动 插入 大 量 数 据 的 时 候 ， 难 免 将 图 书信 息 的 某 个 字段 书写 错误 ， 这 个 时 候 就 需要 使 用 UPDATE 
语句 更 新 信息 。 本 实例 通过 UPDATE 语句 实现 更 新 图 书信 息 ， 运 行 结果 如 图 8.41 所 示 。 


8.41 更 新 图 书信 息 


力 关键 技术 
UPDATE 语句 用 于 修改 表 中 的 数据 ， 通 常 有 两 种 形式 ， 一 种 是 可 以 一 次 向 表 中 修改 多 条 数据 (实现 一 改 全 
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改 ) ; 另 一 种 是 只 修改 一 条 记录 ， 其 语法 格式 如 下 : 
UPDATE{ 
table name WITH (< table hint limited>[..n]) 
| view name 
|rowset function limited 
} 
SET 
{ column_ name = { expression | DEFAULT | NULL } 
| @variable = expression 
| @variable = column = expression } [ ,..n ] 
{ {[FROM { <table source>}[,n]] 
[WHERE 
< search_condition > ] } 


| 
[WHERE CURRENT OF 
{ {[ GLOBAL ] cursor_name } | cursor_variable_name } 


]} 
[OPTION (< query hint>[,..n])] 
<table source> :一 
table name [[ AS ] table alias][ WITH(<table hint>[..n])] 
| view_name [ [ AS ] table_alias] 
| rowset_function [ [AS] table_alias] 
| derived table [AS] table_alias [ ( column alias [ ,..n])] 
|<joined_table > 
<joined table > := 
< table source > < join type > <table source > ON < search condition > 
|<table_source > CROSS JOIN < table_source > 
|<joined_table > 
<join type> 
[INNER | { { LEFT | RIGHT | FULL } [OUTER] } ] 
[<join_hint>] 
JOIN 
<table_hint limited > ::= 
上 FASTFIRSTROW 
HOLDLOCK 
PAGLOCK 
READCOMMITTED 
REPEATABLEREAD 
ROWLOCK 
SERIALIZABLE 
TABLOCK 
TABLOCKX 
UPDLOCK 


} 
<table_hint > 
{INDEX (index val[...n]) 
FASTFIRSTROW 
HOLDLOCK 
NOLOCK 
PAGLOCK 
READCOMMITTED 
READPAST 
READUNCOMMITTED 
REPEATABLEREAD 
ROWLOCK 
SERIALIZABLE 
TABLOCK 
TABLOCKX 
UPDLOCK 


} 
< query_hint > :一 

{ {HASH |ORDER}GROUP 
{ CONCAT | HASH | MERGE } UNION 
{LOOP | MERGE | HASH } JOIN 
|FAST number rows 
FORCE ORDER 
MAXDOP 
ROBUST PLAN 
KEEP PLAN 
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参数 说 明 : 

table_name: 要 更 新 的 表 的 名 称 。 如 果 该 表 不 在 当前 服务 器 或 数据 库 中 ， 或 不 为 当前 用 户 所 有 ， 此 名 称 可 用 
连接 服务 器 、 数 据 库 和 所 有 者 名 称 来 限定 。 

WITH(<table hint limited>[...n]): 指定 目标 表 所 允许 的 一 个 或 多 个 表 提 示 。 需要 有 WITH 关键 字 和 圆 括号 ， 
不 允许 有 READPAST、NOLOCK 和 READUNCOMMITTED。 

view_name: 要 更 新 的 视图 的 名 称 。 通 过 view_name 来 引用 的 视图 必须 是 可 更 新 的 。 用 UPDATE 语句 进行 
的 修改 ， 至 多 只 能 影响 视图 的 FROM 子 句 所 引用 的 基 表 中 的 一 个 。 

rowset_function limited: OPENQUERY 或 OPENROWSET 函数 ， 视 提供 程序 功能 而 定 。 

SET: 指定 要 更 新 的 列 或 变量 名 称 的 列表 。 

column_name: 含有 要 更 改 数据 的 列 的 名 称 。column_name 必须 驻 留 于 UPDATE 子 句 所 指定 的 表 或 视图 中 ， 
标识 列 不 能 进行 更 新 。 
图 设计 过 程 

(1) 建立 inphp 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连接 类 。 

(2) 编写 index.php 文件 。 首 先 包含 数据 库 连 接 文 件 ， 执 行 类 的 实例 化 并 连接 数据 库 ， 然 后 循环 输出 数据 
表 中 的 数据 ， 并 且 为 每 条 记录 创建 一 个 “更 新 ” 超 链接 ， 链 接 到 当前 页 ， 传 递 参 数 为 该 条 记录 的 ID 值 。 最 后 ， 


根据 超 链 接 传递 的 参数 值 进行 判断 ， 如 果 符合 要 求 则 输出 form 表单 ， 将 更 新 数据 提交 到 本 页 ， 完 成 数据 的 更 新 


操作 ， 核 心 代码 如 下 : 
<?php 
include("in.php"); 
new mysql("localhost", "root","111","db_database08"); // 连 接 数 据 库 
if($_POST[sub1D){ 
这 $_POST[na] 一 "更 新 书 名 " || $_POST[nam] 一 "更 新 价格 "||$_POST[name] 一 "更 新 日 期 "){ 
echo "<script>alert( 有 文本 框 未 做 更 新 ， 请 重新 填写 ):location href='index.php?id=1'</script>"; 
jelse{ 
$sql = "update tb_demo027 set bnamc='$_POST[na]',price='$_POST[nam]'datc=S$_POST[name] where id=$_GET[update]"; 
这 mysql_query($sqD){ 
echo "<script>alert( 更 新 成 功 );</script>"; 
} 
} 


国 秘笈 心 法 
心 法 领悟 372: 使 用 UPDATE 语句 的 注意 事项 。 
在 使 用 UPDATE 更 新 语句 时 ， 要 注意 where 子 句 的 使 用 ， 如 果 不 存 在 where 子 句 ， 则 会 更 新 数据 库 中 的 所 


有 数据 。 所 以 ， 在 应 用 UPDATE 语句 执行 更 新 操作 时 ， 必 须 指定 更 新 的 条 件 ， 而 这 个 条 件 最 理想 的 选择 就 是 数 
据 的 ID， 即 数据 表 中 字段 的 主键 。 


高级 


实例 373 Mle de 


| 

| 

上 
力 实例 说 明 


对 于 数据 类 型 相同 的 数据 信息 ， 用 户 没 有 必要 对 数据 进行 逐条 更 新 ， 可 以 通过 批量 更 新 一 次 解决 。 本 实例 
通过 UPDATE 语句 实现 图 书信 息 的 批量 更 新 ， 运 行 结果 如 图 8.42 所 示 。 
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了 好 
大 图 书信 息 的 批量 更 新 


EP 


图 8.42 批量 更 新 
图 关键 技术 
本 实例 实现 批量 更 新 图 书信 息 的 SQL 语句 的 代码 如 下 : 


update tb_demo028 set date='$_POST[name]'where (id>=$_POST[na] and id<=$_POST[nam]); 

本 实例 的 匹配 更 新 是 通过 where 子 句 的 执行 条 件 来 完成 的 ， 更 新 的 是 date 字段 的 值 ， 其 更 新 的 范围 是 id 大 
于 $_POST[na]、 小 于 等 于 $_POST[nam] 的 数据 。 
图 设计 过 程 

(1) 建立 inphp 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连接 类 。 

(2) 编写 index.php 文件 。 首 先 创建 form 表单 ， 将 更 新 数据 提交 到 本 页 ， 然 后 包含 数据 库 连 接 类 并 实例 化 
对 象 ， 接 着 判断 表单 中 提交 的 数据 ， 根 据 判断 结果 执行 不 同 的 更 新 语句 ， 最 后 循环 输出 数据 表 中 的 数据 ， 核 心 
代码 如 下 : 

Iphp 
include("in.php"); 
new mysql("localhost", "root","111","db_database08"); // 连 接 数 据 库 
if($_POST[sub){ 
这 $_POST[m] 一 " 填 入 首 字段 名 称 " | $_POST[name] 一 "更 新 内 容 "|| $_POST[na] 一 " 首 字母 ID"||$_POST[nam] 一 " 尾 字母 ID"){ 
echo "<script>alert(' 请 将 文本 框 内 容 填写 完整 ):</script>": 


这 $_ POST 加] 一 "ID" || $_POST[n] = "id" || $_POST[n] =— "Id" || $_POST[n] — "iD"){ 
echo "<script>alert(TD 主键 无 法 更 新 );:</seript>"; 


} 
if($_POST[n] 一 " 书 名 "){ 
ifmysql_query("update tb_demo028 set bname='$_POST[name]'where (id>=$_POST[na] and id<=$_POST[nam])"){ 
echo "<script>alert( 批 量 更 新 书 名 完成 ):location href="index.php'</script>"; 
yelse{ 
echo "<script>alert( 输 入 信息 有 误 ):</script>"; 
y 
外 
,省略 了 部 分 代码 
} 
Srs = mysql_query("select + from tb_demo028"): 
> 


图 秘笈 心 法 
心 法 领悟 373: UPDATE 批量 更 新 。 


在 本 实例 中 ， 通 过 批量 更 新 将 指定 字段 的 值 统一 更 新 为 一 个 新 的 值 。 还 可 以 通过 批量 更 新 将 指定 字段 更 新 


为 不 同 的 值 ， 完 成 这 个 操作 首先 需要 form 表单 提交 多 个 不 同 的 值 ， 然 后 通过 while 循环 读 取 提 交 的 值 ， 并 且 循 
环 执行 更 新 语句 即 可 实现 。 
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实例 374 


力 实例 说 明 


数据 库 可 以 长 期 存储 数据 ， 但 是 如 果 不 能 及 时 删除 一 些 已 经 过 期 不 再 使 用 的 数据 或 者 宛 余 数据 信息 ， 会 影 
响 到 MySQL 服务 器 的 执行 效率 ， 所 以 删除 不 再 使 用 的 数据 是 十 分 必要 的 。 本 实例 通过 DELETE 语句 实现 删除 
图 书信 息 ， 运 行 结果 如 图 8.43 所 示 。 


删 院 四书 信息 


.Wo ID 
ID。 书 名 
1 ?HP 开发 实战 宝典 
2 人 开发 闫 成 宝贵 
了 Java 开发 实 成 空 典 
Java 有 eb 开 发 实 奈 宝 类 


图 8.43 ”删除 图 书信 息 


图 关键 技术 


DELETE 语句 用 于 删除 表 中 的 数据 ， 通 常 有 两 种 形式 ， 一 种 是 可 以 一 次 删除 表 中 多 条 数据 ， 另 一 种 是 一 次 
只 删除 一 条 记录 ， 其 语法 格式 如 下 : 
DELETE [FROM] 
{table_name | view_name} 
scarch_conditions] 
参数 说 明 : 
table_name: 指定 要 删除 数据 的 数据 表 的 名 称 。 
view_name: 用 于 要 删除 数据 的 视图 。 


search_conditions: 使 用 搜索 条 件 来 限定 要 删除 的 数据 行 。 
图 设计 过 程 
(1) 建立 inphp 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连接 类 。 
(2) 编写 index.php 文件 。 首 先 创建 form 表单 ， 将 删除 数据 的 ID 提交 到 本 页 ， 然 后 包含 数据 库 连接 类 并 


实例 化 对 象 ， 判 断 表 单 中 提交 的 数据 是 否 符合 要 求 ， 如 果 符 合 要 求 ， 则 执行 DELETE 语句 ， 最 后 循环 输出 数据 
表 中 的 数据 ， 核 心 代码 如 下 : 
<?php 


include("in.php"); // 包 含 数据 库 连接 类 
new mysql("localhost","root","111","db_database08"): // 实 例 化 对 象 
if($_POST[sub){ // 单 击 删除 按钮 
iflpreg_match("/\d/",.$_POST[na])){ // 首 先 验证 文本 框 是 否 为 数字 
if(mysql_query("delete from tb_demo029 where id="$_POST[na]"){ /| 执行 删除 操作 
echo "<script>alert( 删 除 成 功 ):</script>"; /输出 提示 


jslse{ 
echo "<script>alert( 您 输入 的 商品 ID 不 在 范围 内 ):</scripf>": 


} 
Jelse{ 
echo "<script>alert( 您 输入 的 图 书 人 D 不 是 数字 ):</script>" 


} 
} 
Srs = mysql_query("select * from tb_demo029"): // 查 询 操作 输出 信息 
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echo "<table width=580px'><td>ID</td><td> 书 名 </td><td> 价 格 </td><td> 日 期 </td></tr>"; 
while($rst = mysql_fetch_row($rs)){ 
echo "<td>".$rst[0]."</td><td bgcolor=#FFFFFF>".$rst[1]."</td><td>".$rst[2]."</td><td bgcolor=#FFFFFF'>".$rst[3]."</td></tr>"; 


} 
echo “</table>"; 
> 


心 法 领悟 374: 使 用 DELETE 语句 的 注意 事项 。 
如 果 用 户 编写 的 DELETE 语句 中 没有 where 子 句 ， 则 所 有 的 字段 信息 都 将 被 删除 。 


让 高 级 | 
起 味 指数 : 庚 志 记 记 ， 
图 实例 说 明 


假设 在 数据 表 中 有 多 条 错误 信息 或 者 元 余数 据 需要 用 户 手动 删除 ， 如 果 用 户 逐 一 删除 ， 比 较 浪费 时 间 ， 降 
低 了 用 户 的 工作 效率 。 本 实例 推荐 一 种 高 效 的 删除 方法 ， 实 现 数据 的 批量 删除 。 运 行 本 实例 ， 如 图 8.44 所 示 ， 
对 网 络 聊天 室 中 的 数据 进行 管理 ， 选 中 一 条 或 者 多 条 数据 ， 单 击 “ 删 除 ”按钮 即 可 实现 将 选中 的 所 有 数据 删除 。 


时 间 加 


5 
古 李 之 使 渗 黄 | 


2007-04-16 ltae. 168.1.110| 


. | 
ororr15 | ,se 108.1.59 


8.44 批量 删除 数据 


力 关键 技术 


批量 删除 数据 同样 应 用 的 是 DELETE 语句 ， 只 是 在 处 理 提交 的 数据 时 应 用 while 循环 语句 、list0 和 eachO 
函数 。list0 函 数 的 语法 如 下 : 

void list(...); 

该 函数 用 于 一 次 性 为 多 个 变量 赋值 。 

each0 函 数 的 语法 如 下 : 

array cach( array array); 

该 函数 用 于 依次 返回 参数 array 所 指定 的 数组 的 元 素 下 标 和 该 下 标 所 对 应 的 数组 元 素 值 , 并 且 每 获取 一 个 数 
组 元 素 后 ， 自 动 使 数组 指针 向 下 移 一 位 。 该 函数 将 返回 一 个 数组 ， 该 数组 的 下 标 只 有 0、key、1 和 value 这 4 
个 数值 ， 其 中 下 标 为 0 和 key 的 数组 元 素 值 相等 ， 表 示 该 函数 的 参数 所 指定 数组 的 当前 元 素 的 下 标 ， 而 下 标 为 
1 和 value 的 数组 元 素 值 相等 ， 表 示 该 参数 所 指定 数组 的 当前 元 素 值 。 

while 循环 语句 是 PHP ll es 该 语句 的 基本 格式 如 下 : 

/ 


while (expr) statement : 
while (expr) : statement ... endwhile : /使 用 著 代 语法 的 格式 


while 循环 是 PHP 最 简单 的 循环 语句 。 只 要 while 表达 式 的 值 为 TRUE 就 重复 执行 该 表达 式 中 的 语句 体 , 如 
果 while 表达 式 的 值 一 开始 就 是 FALSE， 则 循环 语句 体 一 次 也 不 执行 。 


PHP 开发 实例 大 全 (基础 卷 ) 
图 设计 过 程 


(1) 新 建 conn.php， 创 建 与 数据 库 的 连接 ， 其 代码 如 下 : 
<?php 
$conn=mysql_connect("localhost","root","111")or dir(' 服 务 器 连接 失败 :. mysql_error0): 
mysql_select_db("db_database08",$conn); 
mysql_query("set names utf8"); 
?> 


(2) 创建 显示 数据 库 中 数据 的 表格 , 读 取 数 据 库 中 的 数据 ,设置 批量 删除 数据 的 提交 按钮 ， 关 键 代码 如 下 ; 
<?php session_start0; include("conn/conn .php"); 
<form name="formmlr method="post" action="index_ok.php"> 
<table width="486" border="1" cellpadding="0" cellspacing="0"> 
<?php $query=mysql_query("select * from tb_chartroom"); 
这 $query 一 truej{ 
while(Smyrow=mysql fetch_array(Squery){ 


<tr> 
<td align="center"><span class="STYLE2"> 
<input type="checkbox" name="<?php echo $myrow[id]:?>" value="<?php echo $myrowlid]:?>"> 
</span></td> 
<td height="25" align="center"><span class="STYLE2"><?php echo $myrow[username]:?></span></td> 
<td align="center"><span class="STYLE2"><?php echo $myrow[to_usemame]:?></span></td> 
<td align="center"><span class="STYLE2"><?php echo $myrow[text]:?></span></td> 
<td align="center"><span class="STYLE2"><?php echo Smyrow[data]:?></span></td> 
<td align="center"><span class="STYLE2"><?php echo $myrowlip]:?></span></td> 
</t> 
php }}> 
<t> 
<td height="25" colspan="4" align="center">&nbsp;</td> 
<td colspan="2" align="left"><input type="submit" name="Submit" value=" 删 除 "></td> 
<ltr> 
<ltable> 
</form> 


(3) 对 表单 提交 的 数据 进行 处 理 ， 完 整 的 代码 如 下 : 

<?php session_start(); include("conn/conn.php"); 
这 $Submit 一 "删除 ){ 

while(list(S$name,$value)=each($ POST)){ 

Sresult=mysql query("delete from tb chartroom where id=".$name.""); 

if($result==true){ 

echo "<script>alert(' 删 除 成 功 !); window.location href='index.php';</script>"; 
Jelse{ 

echo "<script>alert( 失 败 !); window.location href='index.php';</script>";} 

D 
?> 


力 秘笈 心 法 


心 法 领悟 375: 制作 批量 删除 程序 的 注意 事项 。 


在 制作 批量 删除 程序 时 ， 最 好 建立 提示 页 面 确认 是 否 删除 ， 和 否则 如 果 由 于 意外 删除 数据 ， 会 给 用 户 带 来 不 
必要 的 损失 。 


高 级 


站 one | 


实例 376 


力 实例 说 明 
将 数据 库 中 的 信息 显示 到 网 页 中 经 常会 遇 到 这 样 的 问题 ， 即 网 页 中 输出 的 中 文 文字 为 乱码 。 造 成 该 问题 的 
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主要 原因 是 数据 库 中 的 编码 格式 与 页 面 设置 的 编码 格式 不 符 或 者 没有 将 数据 信息 统一 为 GBK、GB2312 或 
UTF-8。 本 实例 通过 设置 编码 格式 演示 如 何 避 免 输出 中 文字 符 串 时 出 现 乱 码 ， 运 行 结果 如 图 8.45 所 示 。 


8.45 ”错误 设置 编码 格式 输出 中 文 


力 关键 技术 
set 语句 用 于 设置 不 同 变量 ， 其 语法 如 下 


SET variable_assignment [, variable_assignment] ... 
variable assignment: 
|[GLOBAL | SESSION] system ， Var_name = expr 
|@@[global. | session.]system_var_name = expr 
本 实例 通过 set 语句 设置 页 面 的 编码 格式 ， 其 代码 如 下 : 


set names $_POST[name]: 
图 设计 过 程 


编写 脚本 文件 ， 命 名 为 index.php。 创 建 form 表单 ， 将 要 设置 的 编码 格式 提交 到 本 页 。 在 本 页 中 连接 服务 


器 和 指定 的 数据 库 ， 根 据 form 表单 提交 的 数据 设置 数据 库 的 编码 格式 ,然后 循环 输出 数据 库 中 的 数据 ， 其 代码 
如 下 : 


pl 
if$_POST[sub]){ /| 单 击 “确定 ”按钮 
这 $_POST[name] 一 "||$_POST[name] 一 "输入 编码 格式 "){ // 如 果 文本 框 为 空 或 初始 值 
echo "<script>alert( 文 本 框 内 容 不 正确 ):</script>"; 
Jelse{ 
S$conn = mysql_connect("localhost". "root","111") or dir ("connect MySQL false"): /连接 MySQL 数据库 
mysql_select_db("db_database08".$conn) or die ("connect database false"); /连接 数据 库 
mysql_query("set names $_POST[name]"): /设置 编码 格式 
Srs = mysql_query("select * from tb_demo031"): /返回 结果 集 


echo "<table width=-'580px><tr><td bgcolor-#FF0000>ID</td><td bgeolor=#FF0000> 书 名 </td><td bgeolor=#FF0000> 价 格 </td><td 
bgcolor=#FF0000> 日 期 <ftd></tr>"; 


while($rst = mysql_fetch_row($rs){ /循环 输出 
echo "<tr><td bgeolor=#FF0000>".$rst[0]."</td><td bgeolor=#FF0000>".$rst[1]."</td><td bgcolor=#FF0000'>".Srst[2]. 
"</td><td bgeolor=#FF0000>".$rst[3]."</td></tr>"; 
} 
echo "</table>"; 
1 


?> 


国 秘笈 心 ; 
心 法 领悟 376: set 关键 字 的 特点 。 


set 语句 用 于 设置 不 同类 型 的 变量 ， 这 些 变量 会 影响 服务 器 或 客户 端的 操作 。set 关键 字 可 以 用 于 向 用 户 变 
量 或 系统 变量 赋值 。 
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趣味 指教 : 斌 禄 庚 庚 | 


上 
FE 


力 实例 说 明 


创建 数据 库 的 方法 有 很 多 ， 例 如 在 cmd 命令 提示 符 下 通过 create 语句 创建 MySQL 数据 库 ， 或 通过 
phpMyAdmin 等 图 形 化 管理 工具 创建 数据 库 。 本 实例 通过 表单 提交 和 函数 实现 动态 创建 MySQL 数据 库 ， 运 行 
结果 如 图 8.46 所 示 。 


se 
| amMySeLEEB 


二 创 建 所 


本 可 
图 8.46 动态 创建 数据 库 


图 关键 技术 
本 实例 主要 应 用 的 是 SQL 语句 中 的 create database 语句 ，create database 语句 的 格式 如 下 : 


create database db_name ; 
其 中 ，db_name 是 要 创建 的 数据 库 名 称 ， 该 名 称 必须 是 合法 的 ， 不 能 与 其 他 数据 库 重 名 。 
本 实例 实现 创建 数据 库 的 SQL 语句 如 下 : 


create database $_ POST[name]; 


力 设计 过 程 


编写 index.php 文件 ， 引 入 CSS 样式 表 ， 编 写 网 页 页 面 结构 并 包含 图 片 。 当 单 击 “ 创 建 ” 按 钮 时 ， 首 先 对 
文本 框 进行 数据 验证 ， 然 后 连接 MySQL 数据 库 ， 通 过 mysql_query0 函 数 实现 动态 创建 MySQL 数据 库 ， 代 码 


如 下 : 
<?php 
if($_GET[id] = "1){ // 单 击 按钮 
echo "<form action=" method='post>"; /编写 fomm 表单 
echo "<input class='one'type=text size=10' name='name' value=' 数 据 库 名 称 >"; 
ceho "gnbspitnbsp: nbsp:<input class='tiwol type='submit name='sub Value &nbspi&nbsp:&nbspiGnbspiSnbsp&nbspi&nbspy 
echo "</form> 
ifS_POST[sub]){ // 单 击 “ 创 建 ”按钮 
if$_POST[name] 一 "||$_POST[name] 一 "数据 库 名 称 "){ /验证 文本 框 是 否 为 初始 值 或 空 值 
echo "<script>alert( 请 填写 正确 数据 库 名 称 ):</script>": 
jelsef 
if(preg_match("/\w/",$_POST[name]){ // 正 则 表达 式 限制 文本 框 输入 内 容 
Sconn = mysql_connect("localhost". "root","111"): /连接 MySQL 数据 库 
if(mysql_query("create database $ POST[name]"){ // 如 果 创 建成 功 
echo "<script>alert(' 创 建 数据 库 成 功 ):</script>"; /| 输出 提示 
Yelse{f 
echo "<script>alert(' 请 不 要 使 用 特殊 字符 或 中 文字 符 );</script>":; 
} 
1 
} 
} 
> 
力 秘笈 心 法 


心 法 领悟 377: 对 于 合法 的 数据 库 〈 包 括 MySQL 其 他 操作 对 象 ) 的 命名 规则 。 
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(1) 名 称 可 以 由 任意 字母 、 数 字 、“ ”或 者 “$” 组 成 ， 可 以 使 用 上 述 的 任意 字符 开头 ， 但 不 能 使 用 单独 
的 数字 ， 那 样 会 造成 其 与 数值 的 混淆 。 

(2) 名 称 长 度 的 限制 为 : 数据 库 、 表 、 列 和 索引 的 名 称 最 多 由 64 个 字符 组 成 ， 而 别名 最 长 可 达 256 个 字符 。 

(3) 不 能 使 用 MySQL 的 关键 字 作为 数据 库 名 和 表 名 。 


实例 378 


图 实例 说 明 


单纯 地 创建 数据 库 毫 无 意义 , 因为 所 有 的 数据 都 是 以 数据 表 的 形式 存储 在 数据 库 中 。 本 实例 通过 create table 
语句 实现 动态 创建 数据 表 ， 运 行 结果 如 图 8.47 所 示 。 


8.47 动态 创建 数据 表 


图 关键 技术 
本 实例 主要 应 用 SQL 语句 中 的 create table 语句 来 动态 创建 数据 表 。create table 语句 的 语法 如 下 : 


CREATE [TEMPORARY] TABLE [IF NOT EXISTS] table_ name 
[(ereate_definition,...)][table_options] [select_statement] 


本 实例 实现 动态 创建 数据 表 的 SQL 语句 如 下 : 

create table $_POST[n](id int(4) auto_increment primary key); 
图 设计 过 程 

创建 index.php 文件 , 首先 通过 下 拉 列 表 框 循环 输出 数据 库 中 存储 的 数据 , 然后 选择 指定 的 数据 库 , 单 击 “ 确 
定 ” 按 钮 ， 在 弹出 的 文本 框 中 添加 数据 表 名 称 并 且 指 定编 码 格 式 ， 单 击 “确定 ”按钮 ， 提 交 创 建 数据 表 的 数据 。 
最 后 获取 form 表单 提交 的 数据 ， 完 成 数据 表 的 创建 操作 ， 其 关键 代码 如 下 : 

< 


php 
if$_POST[sub1]){ // 单 击 “ 确 定 ”按钮 
这 $_POSTm] 一" | $_POST[n] 一 "数据 表 名 称 "){ /验证 文本 框 是 否 为 空 或 初始 值 
echo "<script>alert(' 请 填写 正确 的 数据 表 名 称 ");</script>"; /输出 提示 
Jelse{ 
iflpreg_match("/\w/",$_POST[n]) { // 过 滤 中 文字 符 和 特殊 字符 
if($_POST[selectl] (= "111"){ // 如 果 下 拉 列 表 框 值 不 为 111 
// 连 接 MySQL 数据 库 
Sconn = mysql_connect("localhost". "root","111") or die ("connect mysql false"); 
// 连 接 数 据 库 
mysql_select_db("$_SESSION[id]".$conn) or die("connect database false"): 
mysql_query("SET NAMES $_POST[select1]"): // 设 置 编码 格式 
// 如 果 创 建 数 据 表 成 功 
这 mysql_query("ereate table $_POST[n](id int(4) auto_inerement primary key):"){ 
/输出 提示 


echo "<script>alert(' 创 建 数据 表 成 功 ):location hre 全 index.php?id=2:</script>": 
} 
Jelse{ 
echo "<script>alert(' 请 选择 编码 格式 ):</scripf>": 
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} 
Jelse{ 
echo "<script>alert( 数 据 表 名 称 不 能 包含 特殊 字符 或 汉字 '):</script>"; 
和 
} 
} 
?> 


心 法 领悟 378: 创建 数据 表 的 注意 事项 。 
创建 数据 表 时 系统 要 求 至 少 包含 一 个 字段 ， 空 数据 表 是 不 允许 创建 的 。 


力 实例 说 明 


数据 表 是 由 多 个 字段 组 成 的 ， 字 段 又 分 为 是 什么 数据 类 型 、 是 否 设置 主键 、 是 否 可 以 为 空 、 选 择 设置 编码 
格式 等 。 本 实例 通过 SQL 语句 实现 动态 创建 数据 字段 ， 运 行 结 果 如 图 8.48 所 示 。 


趣味 指数 : 二 三 丰 宙 


动态 创建 MYSQL 元 据 字 愉 
PT he 


] sz [JE 
3 es] Fa 
ma ey] FAT 
3 ere] Fa 
3 ers eae 


8.48 动态 创建 MySQL 数据 字段 


力 关键 技术 
本 实例 实现 动态 创建 数据 字段 的 SQL 语句 如 下 : 


$sqll = "ereate table tb_demo035("; 
.$_POST[textl_id] ." "."int(".$_POST[text3 id].")"." "."primary key auto 
POST["n".$b]." ".$_POST["select_type".$b]."(".$_POST["length".$b]. "ns ee selectvSb] we 


图 设计 过 程 
编写 脚本 文件 index php。 首 先 连 接 数据 库 服务 器 和 数据 库 ， 然 后 读 取 服 务 器 中 存储 的 数据 库 ， 根 据 选择 的 


数据 库 ， 创 建 form 表单 ， 提 交 数 据 表 名 称 、 字 段 名 称 和 编码 格式 ， 最 后 获取 表单 中 提交 的 数据 ， 执 行 数 据 表 中 
字段 的 添加 操作 ， 其 核心 代码 如 下 : 


if($_POST[sub1] ){ / 单 击 按钮 
/拼接 字符 串 
$sq=""$_POST[textl id] .™ "."int(".$_POST[text3 id].")"." "."primary key auto_increment"; 
$_SESSION[sq] = $sq: /保存 于 SESSION 中 
for($b = 0:Sb <$_SESSION[id]:$b++){ /| 循环 语句 
if($_POST["select type".$b] — "1"){ /确定 类 型 
echo "<script>alert( 请 选择 数据 类 型 ):location href='index.php';</seript>"; 
Jelse{ 
1/ 判断 字 段 长 度 值 


518 


第 8 章 MySQL 数据 库 与 PHP 
这 $_ POST["length".$b] !="" || $_POST["length".$b] != "长 度 / 值 "){ 


iflpreg_match("/\d/".$_ POST["length".$b])){ // 正 则 表达 式 
$sql="".$ POST["n".$b]." ".$_POST["select type".$b]."(".$_POST["length".$b].")"." ".$_POST["select".$b].","; 
$_SESSION['sql'.$b] = $sql: /保存 于 SESSION 

jelsef 


echo "<script>alert( 不 是 一 个 数字 "):location href='index.php':</script>"; 
» 
} 
} 


} 


$sqll = "create table tb_demo035("; // 定 义 字符 串 
/定义 字符 串 
/定义 数组 
for($d=0:$d<$_SESSION[id]:$d++){ /循环 语句 
array_push($array,$_SESSION[sql.$d]); 
Sarr = implode(Sarray); // 合 并 字符 串 
$s = $sqll.Sarr.$sq.$sql2; // 合 成 SQL 语句 
// 连 接 MySQL 
$conn = mysql_connect("localhost", "root"."111") or die("connect mysql false"); 
// 连 接 数据 库 
mysql_select_db("db_database08".$conn) or die("connect database false"); 
mysql_query("set names utf8"); // 设 置 编码 格式 
if(mysql_query($s){ // 执 行 创建 
echo "<script>alert(' 动 态 创建 数据 字段 成 功 );</script>"; 
Jelse{ 
echo "<script>alert(' 已 存在 数据 库 ")</script>"; 
} 
} 
> 
>» 二 
力 秘笈 心 法 


心 法 领悟 379: 动态 创建 字段 还 可 以 使 用 SQL 中 的 alter table 语句 实现 。 

动态 创建 字段 只 是 向 指定 的 数据 表 中 添加 新 的 字段 及 字段 属性 值 。 修 改 表 的 操作 语句 为 alter table， 主 要 实 
现 对 数据 表 结构 进行 操作 ， 也 可 以 对 表 中 的 列 进行 添加 或 删除 、 创 建 或 撤销 索引 、 更 改 现 有 列 的 类 型 或 更 改 列 
或 表 的 名 称 及 修改 表 的 注释 和 类 型 。 该 语句 的 格式 如 下 : 


alter [nore] table table name action isty 

参数 说 明 : 

该 语句 允许 指定 多 个 动作 ， 其 动作 间 使 用 逗号 分 隔 ， 每 个 action 表示 对 表 的 一 个 修改 。 它 不 仅 能 够 同时 执 
行 多 个 修改 操作 ， 还 可 以 同时 将 所 有 varchar 列 更 改 为 char 列 ， 从 而 实现 将 行 可 变 的 表 更 改 为 行 定 长 的 表 。 在 
表 8.2 中 列 出 了 alter table 语句 的 常用 功能 。 

表 8.2 altertable 语句 的 常用 功能 

功 能 示例 语句 说 了 明 
对 表 重 新 命名 |alter table table name rename as new_table name: | 只 需 给 出 原 表 名 和 新 表 名 即 可 
该 语句 将 s_table 表 中 的 列 id 由 smallint unsigned 类 型 更 
改 为 nt unsigned 类 型 
第 3 条 语句 中 , 使 用 change 既 更 改 了 id 的 类 型 , 又 重新 
将 这 命 名 为 sid 
在 字符 串 中 ， 定 长 的 列 一 般 比 变 长 的 列 处 理 得 快 。 如 语 
名 中, s_table 中 列 user 的 类 型 是 varchar, 将 其 转换 为 定 


alter table s_table modify id int unsigned: 
更 改 列 的 类 型 |altertable s table change id int unsigned:; 
alter table s_table change id sid int unsigned: 


将 字符 串 列 从 可 alter table s_table modify user char (30): 


2 长 的 char 列 ， 可 提高 查询 的 效率 
将 字符 串 列 从 定 虽然 字符 串 使 用 定 长 的 行 查询 效率 高 ， 但 是 却 占用 了 很 
长 转 为 可 变 长 alter table s_ table modify user varchar (30): 多 空间 ， 而 使 用 变 长 的 字符 串 列 却 能 够 节省 空间 ， 使 转 


换 的 效率 更 高 
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8.6 SQL 查询 语句 


本 节 将 介绍 在 PHP 语言 中 ， 如 何 运 用 SQL 语言 中 的 查询 语句 查询 数据 库 中 的 数据 。 


实例 380 


力 实例 说 明 


在 实际 的 项 目 开发 过 程 中 ,经 常 需要 在 数据 库 中 建立 一 些 数值 型 字段 保存 信息 ， 例 如 商品 的 数量 、 价 格 等 。 
运行 本 实例 ， 


本 实例 将 通过 在 数据 库 中 查询 库存 剩余 量 大 于 100 的 商品 信息 ， 来 说 明 查 询 数 值 型 数据 的 方法 。 
如 图 8.49 所 示 ， 图 中 显示 的 为 库存 量 大 于 100 的 商品 。 


20 
2010-07-19 


8.49 大 于 100 的 数据 


图 关键 技术 


本 实例 实现 查询 大 于 100 的 数据 的 SQL 语句 如 下 : 


select * from tb_demo036 where sum > 100: 


高 级 


趣味 指数 : 会 食 祖 食 


看 设计 过 程 
编写 index.php 文件 。 建 立 数据 库 连 接 ， 显 示 所 有 满足 库存 量 大 于 100 的 商品 信息 ， 代 码 如 下 : 
<2php 
if($_POST[sub){ / 音 击 按钮 
$conn = mysql_connect("localhost","root","111") or die("connect mysql false"); ” // 连 接 MySQL 
mysql_select_db("db_database08".$conn) or die("connect database false"): // 连 接 数据 库 
mysql_query("set names utf8"); // 设 置 编码 格式 
Srs = mysql_query("select * from tb_demo036 where sum > 100"): /返回 结果 集 


> 
<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 剩 余 </td><td background="pic/head.JPG"> 日 期 </td></tr> 
<2php 
while($rst = mysql_fetch_row($rs){ /循环 输出 
echo "<tr><td background=pic/head. JPG’>".$rst[0]."</td><td background='pic/head.JPG'>".$rst[1]."</td><td 
background='pic/head.JPG>".$rst[2]."</td><td background=pic/head.JPG'>".$rst[3]."</td></tr>": 


} 
ke 
国 秘笈 心 法 
心 法 领悟 380: 列举 相关 的 查询 谓词 。 


本 实例 的 SQL 查询 语句 包含 谓词 “>”， 查 询 谓词 还 包括 “=”、“<>”、“!=”、“>”、“<”、“>= 


] 
sx 
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“=<”、“I<” 和 “!>”。 
力 实例 说 明 


对 字符 串 进行 查询 是 项 目 开发 过 程 中 应 用 几率 最 高 的 查询 ， 并 且 这 种 查询 经 常 与 通配符 配合 使 用 实现 信息 
的 匹配 查询 。 运 行 本 实例 ， 效 果 如 图 8.50 所 示 。 


《PIF 范例 大 全 为 


图 8.50 查询 字符 串 


图 关键 技术 


使 用 SQL 语句 可 以 对 字符 串 进行 完全 匹配 查找 和 模糊 查找 ， 如 果 对 字符 串 进行 匹配 查找 则 直接 用 等 号 作为 
查询 条 件 的 连接 谓词 ， 如 果 对 字符 串 进行 模糊 查找 则 用 like 关键 字 作为 连接 谓词 。 下 面 将 通过 具体 实例 讲解 如 
何 实现 对 字符 串 的 查找 。 

(1) 从 学 生成 绩 表 〈tb_score) 中 查询 所 有 名 为 “小 刘 ” 的 学 生 信息 ， 其 中 学 生 姓名 字段 为 sname。 
select * from tb_score where sname=" 小 刘 " 

(2) 从 学 生 表 (tb_student〉 中 查询 所 有 姓 “ 刘 ”的 学 生 信 息 ， 其 中 学 生 姓名 字段 为 sname。 

select * from tb_student where sname like ' 刘 96 


(3) 从 职工 表 (tb_worker) 中 查询 所 有 职务 为 “程序 员 ” 的 员工 信息 ， 其 中 员工 职务 字段 为 zhiwu。 
select * from tb_worker where zhiwu like % 程 序 员 ' 


(4) 从 图 书信 息 表 (tb_book〉 中 查询 所 有 PHP 类 相关 图 书 ， 其 中 书 名 字段 为 bookname。 


select * from tb_book where bookname like '%ePHP96' 


图 设计 过 程 

编写 index.php 文件 ， 连 接 MySQL 数据 库 ， 显 示 查 询 到 的 图 书信 息 ， 代 码 如 下 : 

<?php 

if$_POST[sub]){ // 单 击 按钮 
Sconn = mysql_connect("localhost", "root"."111") or die("connect mysql false"): /连接 MySQL 
mysql_select_db("db_database08".$conn) or die("connect database false"): // 连 接 数 据 库 
mysql_query("set names utf8"); // 设 置 编码 格式 
// 返 回 结果 集 
Srs = mysql._query("select * from tb_demo036 where name like %$_POST[select]o6"); 

> 


<table width="580px"><tr><td background="pic /head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 剩 余 </td><td background="pic/head.JPG"> 日 期 </td></tr> 
<2php 

while(Srst = mysql_fetch_row(Srs){ /循环 输出 

echo "<tr><td background='pic/head. JPG>".$rst[0]."</td><td background='pic/head.JPG'>".$rst[1]."</td><td 

background='pic/head.JPG>".$rst[2]."</td><td background='pic/head. JPG'>" Srst[3]."</td></tr>"; 

} 
} 


> 
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心 法 领悟 381: 对 关键 字 like 的 评价 。 
对 字符 串 进 行 模糊 查找 可 以 使 用 like 关键 字 。like 关键 字 十 分 重要 ， 几 乎 在 所 有 网 站 的 站 内 搜索 模块 中 都 
有 其 身影 。 


级 | 
实例 382 趣味 指数 ; 请 寅 请 二 * 
实例 说 明 


对 日 期 型 数据 进行 查询 在 商业 网 站 中 得 到 了 广泛 的 应 用 ， 例 如 查询 员工 的 出 生日 期 、 商 品 的 进货 时 间 等 。 
本 实例 将 在 图 书信 息 表 中 查询 图 书 出 版 日 期 为 “2010-07-19” 的 图 书信 息 ， 运 行 本 实例 ， 效 果 如 图 8.51 所 示 。 


和 *C++ 范 例 大 全 》 


图 8.51 查询 日 期 型 数据 


图 关键 技术 


本 实例 实现 查询 日 期 型 数据 的 SQL 语句 如 下 : 


select * from tb_demo036 where date ='2010-07-19"; 


查询 tb_demo036 数据 表 中 所 有 时 间 date 等 于 “2010-07-19” 的 数据 。 
图 设计 过 程 

建立 index.php 文件 ， 连 接 MySQL 数据 库 ， 当 单 击 “ 显 示 数 据 ” 按 钮 时 ， 程 序 会 自动 显示 出 版 日 期 为 
“2010-07-19” 的 所 有 图 书 ， 代 码 如 下 : 

<Iphp 


if($_POST[sub) { // 单 击 按钮 
Sconn = mysql_connect("localhost", "root","111") or die("connect mysql false"): /连接 MySQL 
mysql_select_db("db_database08".$conn) or die("connect database false"): // 连 接 数 据 库 
mysql_query("set names utf8"); /设置 编码 格式 
S$rs = mysql_query("select + from tb_demo036 where date = '2010-07-19"; // 返 回 结果 集 
> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 剩 余 </td><td background="pic/head.JPG"> 日 期 </td></tr> 
<Iphp 
while($rst = mysql_fetch row(Srs)){ /循环 输出 结果 
echo "<tr><td background='pic/head JPG>" Srst[0] "</td><td background='pic/head.JPG'>".$rst[1]."</td><td 
background='pic/head.JPG>".$rst[2]."</td><td background='pic/head. JPG'>" Srst[3]."</td></tr>": 
} 


} 
> 


国 秘笈 心 法 
心 法 领悟 382， 不 同 数 据 库 查询 日 期 型 数据 存在 差异 。 


522 


第 8 章 MySQL 数据 库 与 PHP 


不 同 的 数据 库 对 日 期 型 数据 的 查询 是 有 区 别 的， 下 面 将 以 几 种 典型 的 数据 库 为 例 讲解 在 不 同 的 数据 库 中 对 
日 期 型 数据 的 查询 方式 。 
下 面 的 讲解 都 是 以 在 图 书 表 (tb_demo036) 中 查询 出 版 日 期 (date) 为 “2010-07-19” 为 例 进 行 讲解 的 。 


(1) MySQL 数据 库 中 对 日 期 型 数据 的 查询 
sclect * from tb_demo036 where birthday=2010-07-19" 


(2) SQL Server 数据 库 中 对 日 期 型 数据 的 查询 


select * from tb_demo036 where birthday=2010-07-19" 


(3) Access 数据 库 中 对 日 期 型 数据 的 查询 


select * from tb_demo036 where birthday=#2010-07-19# 
通过 上 面 3 个 例子 可 以 发 现 ， 在 MySQL 数据 库 和 SQL Server 数据 库 中 实现 对 日 期 型 数据 查询 所 要 查询 的 
日 期 应 用 单 引号 括 起 来 ， 而 在 Access 数据 库 中 使 用 JET SQL 语法 查询 时 所 查询 的 日 期 应 用 “#” 号 括 起 来 。 


实例 383 


趣味 指教 : 妇女 妇女 


力 实例 说 明 

逻辑 型 数据 是 一 种 比较 特殊 的 数据 类 型 ， 该 类 型 数据 只 有 逮 辑 真 和 逻辑 假 两 个 值 ， 并 且 有 专门 的 逻辑 运算 
符 用 于 完成 逻辑 运算 。 运行 本 实例 , 如 图 8.52 所 示 , 在 图 中 的 下 拉 列 表 框 中 选择 图 书 的 销售 情况 , 然后 单 击 “ 查 
看 ”按钮 即 可 将 所 有 的 剩余 图 书 或 已 销售 图 书 的 信息 显示 出 来 。 


Tea 


1 《PRP 范 创 大 全 》 150 志 
3 YE 范例 大 全 》 ? 味 


8.52 查询 图 书库 存 和 销售 情况 


力 关键 技术 


专门 的 逻辑 运算 符 主要 包括 and、or、not, 分 别 表示 与 运算 、 或 运算 和 非 运算 。 逻辑 运算 符 的 优先 级 为 not、 
and 和 or， 这 3 个 运算 符 的 使 用 说 明 如 下 。 
回 not; 如 果 原来 表达 式 或 参数 的 值 为 逻辑 真 ， 则 取 非 运算 后 的 结果 为 逻辑 假 。 反 之 如 果 原 来 表达 式 的 值 
为 逻辑 假 ， 则 取 非 运算 的 结果 为 逻辑 真 。 
and: 两 个 或 多 个 表达 式 进行 逻辑 与 运算 ， 如 果 有 一 个 为 假 则 运算 结果 为 假 。 
or: 两 个 或 多 个 表达 式 进行 逻辑 或 运算 ， 如 果 有 一 个 为 真 则 运算 结果 为 真 。 
本 实例 实现 查询 逻辑 型 数据 的 SQL 语句 的 格式 如 下 : 


select * from tb_demo039 where type = T" 
select * from tb_demo039 where type = 下" 


图 设计 过 程 
编写 主页 文件 index.php， 连 接 MySQL 数据 库 ， 通 过 判断 下 拉 列 表 框 信息 显示 运行 结果 ， 代 码 如 下 : 
omy // 单 击 “ 确 定 ” 按 钮 
if($_POST[select] — "stock"): // 判 断 下 拉 列 表 框 信息 


{ 
S$sql ="select * from tb_demo039 where type ="T"; 
Jelse{ 


PHP 开发 实例 大 全 (基础 卷 ) 
S$sql = "select * from tb_demo039 where type = 下": 
} 
// 连 接 MySQL 数据 库 


$conn = mysql_connect("localhost"."root","111") or die("connect mysql false"); 
mysql_select_db("db_database08", $conn) or die ("connect database false"):; 


mysql_query("set names utf8"); /设置 编码 格式 
Srs = mysql_query(Ssq]): /返回 结果 集 
?> 
<table width="580px"><tr><td>ID</td><td> 书 名 </td><td> 销 量 与 存量 <td><jtr> 
< 
while(Srst = mysql_fetch_row($rs){ // 循 环 输出 结果 
<tr><td><?php echo $rst[0]:?></td><td bgeolor="#FFFFFF"><?php echo S$rst[1]:?></td><td bgcolor="#FFFFFF"><?php echo Srst[2]." 本 
2><ltd><ltr> 
<?php 
} 
} 
?> 


心 法 领悟 383: SQL 语句 中 的 逻辑 运算 符 。 

在 SQL 语句 中 逻辑 运算 符 主要 包括 and、or、not， 分 别 表示 与 运算 、 或 运算 和 非 运算 。 

高 级 | 
| 


实例 384 趣味 指数 : 傅 食 依依 


力 实例 说 明 


向 数据 库 中 添加 信息 时 ， 有 时 无 法 将 某 些 信息 完整 地 录入 ， 为 了 避免 程序 出 错 ， 需 要 查询 某 条 字段 的 内 容 
完全 不 为 空 的 情况 ， 例 如 本 实例 将 所 有 商品 的 图 片 路 径 存储 在 数据 库 中 ， 一 旦 某 件 商品 的 存储 路 径 丢 失 ， 则 可 
能 导致 图 片 无 法 正常 显示 。 运 行 本 实例 ， 如 图 8.53 所 示 ， 以 分 栏 的 形式 显示 出 所 有 数据 库 中 商品 图 片 路 径 不 为 
空 的 商品 图 片 。 


图 8.53 查询 非 空 数据 


力 关键 技术 


查找 非 空 数据 可 以 通过 where 关键 字 后 加 如 下 条 件 进行 限定 : 
where 字段 名 <>" 


本 实例 中 实现 查询 所 有 商品 图 片 路 径 不 为 空 的 商品 信息 的 SQL 语句 如 下 : 


select * from tb_spxx where address<>" order by addtime desc 


力 设计 过 程 
(1) 建立 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 
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<?php 
Sconn=mysql_connect("localhost", "root","111"); /连接 MySQL 
mysql_select_db("db_database08",$conn); /连接 数据 库 
mysql_query("SET NAMES UTF8"); // 设 置 编码 格式 
?> 


(2) 新 建 ndex.php 文件 ， 以 分 栏 的 形式 显示 所 有 商品 图 片 不 为 空 的 商品 信息 ， 代 码 如 下 : 
<?php 


include_once("conn.php"); // 包 含 数据 库 连 接 页 
$sql-mysql_query("seleet * fiom tb_spxx where addressc> order by addtime dese "Seonn); 
| fetch_array($sq]); // 取 得 结果 集 
if(Sinfo=—false) { 1/ 判断 结果 集 是 否 存在 
echo " 暂 无 商品 信息 !"; // 不 存在 

Jelse{ // 存 在 

$i=0; // 定 义 变量 
do{ 

if($i%3!=0){ 
> 


<td width="50"><img sre=<?php echo $info[address]:?> width="100" height="100" /></td> 
<td width="20" rowspan="2">&nbsp:<ltd> 


<t> 
<td height="20">&nbsp:</td> 
<tr> 


<td width="50"><img src=<?php echo $info[address]:?> width="100" height="100" /></td> 
<td width="20" rowspan="2">&nbsp;</td> 
<?php 
上 
Sit+t; 
}while(Sinfo=mysql fetch_array($sqD)); /| 循环 输出 数据 
} 
?> 


国 秘笈 心 法 


心 法 领悟 384: SQL 语句 与 PHP 编码 的 符号 差异 。 
在 本 实例 中 ， 不 等 于 使 用 符号 “<> ”表示 ， 相 当 于 PHP 语法 中 的 “ 


实例 385 趣味 指数 : 容 窒 本 二 


力 实例 说 明 


通过 变量 查询 商品 等 信息 在 实际 项 目 开 发 过 程 中 也 被 广泛 应 用 , 例如 查询 指定 范围 内 图 书 的 数量 、 价 格 等 。 
本 实例 将 根据 图 书 的 ID 查询 商品 的 所 有 信息 。 运 行 本 实例 ， 如 图 8.54 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 要 查 
询 图 书 的 ID， 单 击 “ 查 看 ”按钮 即 可 按 要 求 查找 到 满足 条 件 的 图 书信 息 。 


PHP 开 发 实战 宝 奥 


图 8.54 ”利用 变量 查询 数值 型 数据 


PHP 开发 实例 大 全 (基础 卷 ) 


图 关键 技术 


利用 变量 查询 数值 型 数据 时 ， 传 入 SQL 语句 的 变量 可 以 不 用 引号 括 起 来 ， 这 是 因为 PHP 中 的 字符 串 与 数 
值 型 数据 进行 连接 时 ， 程 序 会 自动 将 数值 型 数据 转变 成 字符 串 ， 然 后 与 要 连接 的 字符 串 进行 连接 。 


图 设计 过 程 
编写 脚本 文件 index.php， 连 接 MySQL 数据 库 。 根 据 提交 的 ID 号 显示 运行 结果 ， 代 码 如 下 : 


<pl 
if($_POST[sub){ / 单 击 “ 查 看 ”按钮 
if$_POST[text] 一 "||$_POST[text] 一 "输入 ID 查询 "){ 1/ 判断 文本 框 是 否 为 空 或 为 初始 值 
echo "<script>alert(' 请 输入 ID 值 );</script>"; /JavaScript 提示 
Jelse{ 
iflpreg_mateh("/\d/"$_POST[text]){ /正则 表达 式 验证 是 否 为 数字 
/连接 MySQL 数据 库 
Sconn = mysql_connect("localhost","root"."111") or die("connect mysql false"): 
/连接 数据 库 
mysql_sclect_db("db_database08",Sconn) or die("connect database false"); 
mysql_query("set names utf8"); // 设 置 编码 格式 
/返回 结果 集 
Srs = mysql_query("select * from tb_demo031 where id='$_POST[text]"); 
S$rst = mysql_fetch_row($rs); /结果 输出 
> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td_ background="pic/head.JPG"> 书 名 <ltd><td 
background="pic/head.JPG"> 价 格 </td><td background="pic/head.JPG'> 日 期 <ltd></tr> 
<tr><td><?php echo S$rst[0];?></td><td bgcolor="#FFFFFF"><?php echo S$rst[1]:?></td><td><?php echo $rst[2]:?></td><td 
bgeolor="#FFFFFF"><?php echo $rst[3];2></td></tr></table> 
<?php 
yelse{ 
echo "<script>alert( 您 输入 的 不 是 一 个 数字 ');</script>"， ”//JavaScript 提示 
} 
} 


> 
图 秘笈 心 法 
心 法 领悟 385: 查询 语句 的 不 同形 式 。 
本 实例 实现 按 商 品 ID 进行 查询 的 代码 如 下 : 


S$sql=mysql_query("select * from tb_goods where id='$_POST[text] ".Sconn; 


上 述 代码 也 可 以 改写 成 下 面 的 形式 : 


ES 

aa 一 一 a ) 

实例 386 趣味 指数 : 妇女 太太 
图 实例 说 明 


在 实际 项 目 开发 过 程 中 ， 可 以 将 相应 的 数据 经 过 一 系列 的 运算 后 赋 给 一 个 变量 ， 然 后 将 该 变量 传 入 程序 中 
所 要 执行 的 SQL 语句 , 所 以 利用 变量 查询 数据 的 应 用 几率 是 较 高 的 。 本 实例 首先 将 要 查询 的 书 名 赋予 一 个 变量 ， 
然后 将 该 变量 传 入 SQL 语句 实现 按 书 名 进行 匹配 查询 ， 运 行 结果 如 图 8.55 所 示 。 
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四书 名 价格 习 期 

1 PR 开发 实 成 主 夫 BE 0 
有 pi 范 仙 宇宙 BE PPT 
1 范本 让 ET 
11 PRP 范例 字 自 15 元 2010-0T-17 
全 PR 范 疝 主 表 ET 
1 PR 和 全 本 灿 ET 


图 8.55 利用 变量 查询 字符 串 数据 


图 关键 技术 


利用 变量 实现 数据 的 查询 , 经 常 需 要 通过 表单 提交 、 获取 要 查询 的 内 容 , 并 将 该 内 容 赋 予 某 变量 后 传 入 SQL 
语句 执行 查询 ， 并 通过 $_ POST 方式 进行 接收 。 

本 实例 中 实现 按 图 书 名 称 进行 匹配 查询 的 代码 如 下 : 

$sql=mysql_query("select * from tb_demo031 where bname like %S_POST[text] %"); 

由 于 传 入 SQL 语句 的 参数 为 字符 型 数据 ， 所 以 应 在 传 入 参数 的 两 侧 加 上 单 引号 表示 该 数据 为 字符 型 ， 否 则 
程序 将 发 生 类 型 不 匹配 的 错误 。 该 语句 还 可 以 写成 如 下 形式 : 

$sql=mysql_query("select * from tb_demo031 where bname like %'.$_POST[text].'%",$conn); 

这 是 因为 PHP 中 的 字符 串 有 两 种 表示 形式 ， 一 种 是 可 以 将 字符 串 用 单 引 号 括 起 来 ， 另 一 种 是 将 字符 串 用 双 
引号 括 起 来 。 如 果 采 用 第 二 种 表示 形式 ，PHP 变量 可 以 直接 写 在 该 字符 串 中 ， 系 统 并 不 会 将 该 变量 看 作 是 字符 
串 的 一 部 分 ， 还 是 将 其 当 作 PHP 的 合法 变量 。 


图 设计 过 程 


编写 文件 index.php， 设 计 网 页 框架 ， 连 接 MySQL 数据 库 ， 根 据 提示 当 单 击 “ 查 看 ”按钮 时 ， 将 传 入 的 字 
符 串 应 用 于 SQL 语句 中 实现 模糊 查询 ， 代 码 如 下 : 


<?php 
这 $_POST[sub]){ // 单 击 “ 查 看 ”按钮 
这 $_POST[text] 二 "|| $_POST[text] 一 "输入 图 书 名 称 "){ // 当 文本 框 为 空 或 初始 值 
echo "<script>alert( 输 入 图 书 名 );</script>"; /输出 提示 
yelse{ 
S$conn = mysql_connect("localhost","root","111") or die("connect mysql false"); /连接 MySQL 
// 连 接 数 据 库 
mysql_select_db("db_database08",.Sconn) or die("connect database false"): 
mysql_query("set names utf8"); /设置 编码 格式 
Srs = mysql_query("select * from tb_demo031 where bname like '%S$_POST[text9o; // 返 回 结果 集 


echo'<table width="580px"><tr><td «background="pic/head. JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td ”background="pic/head.JPG"> 日 期 </td></tr>'; 
while($rst = mysql_fetch_array($rs){ 1/ 循环 输出 结果 


> 


<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo S$rst[21:?></td><td background="pic/head.JPG"><?php echo $rst[31:?></td></tr> 
<?php 
} 


} 


?> 


国 秘笈 心 ; 


心 法 领悟 386: 完全 匹配 的 方法 。 
本 实例 中 使 用 了 完全 匹配 符 “%%”， 表 示 查 询 字符 串 可 以 出 现在 任何 位 置 。 
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趣味 指教 : 走 相 站 页 ， 


3 


力 实例 说 明 


在 图 书 管理 系统 中 ， 经 常 需要 查询 前 n 本 书 的 详细 信息 。 运 行 本 实例 ， 如 图 8.56 所 示 ， 首 先 在 图 中 的 文本 
框 中 输入 要 查询 的 记录 个 数 ， 单 击 “ 查 看 ”按钮 即 可 按 要 求 查 找到 满足 条 件 的 图 书信 息 。 


这 
1 PhP 开 发 实战 宝典 30 无 
TB 开发 实战 宝典 30 无 


8.56 查询 前 n 条 数据 


力 关键 技术 


关键 字 limit 是 MySQL 数据 库 的 扩展 部 分 ,利用 它 可 以 实现 查询 从 指定 位 置 开 始 满足 一 定 条 件 的 n 条 记录 ， 
如 果 n 超出 表 的 范围 ， 则 只 显示 从 指定 位 置 开 始 到 表 结 束 的 所 有 记录 。 本 实例 通过 如 下 代码 实现 查找 指定 的 前 
和 * from tb_student where classname like '%".$classname."%' order by userid desc limit 0,$number ",$conn); 
图 设计 过 程 
ee index.php 文件 ， 开 启 MySQL 服务 ， 连 接 MySQL 数据 库 ， 当 单 击 “ 查 看 ”按钮 时 ， 显 示 前 n 条 记录 ， 
下 : 


<?php 
if$_POST[sub]){ / 单 击 “ 查 看 ”按钮 
这 $_POST[tex] 一 "||$_POST[text] 一 "输入 图 书 名 称 "){ // 判 断 文本 框 是否 为 空 或 初始 值 
echo "<script>alert( 输 入 图 书 名 ");</seript>"; //JavaScript 提示 
Jelse{ 
if(preg_match("/\d/",$_POST[text]){ /正则 表达 式 过 滤 字符 
$conn = mysql_connect("localhost","root","111") or die("connect mysql false"); /连接 MySQL 
mysql_sclect_db("db_databasec08".Sconn) or die("connect database false"); // 连 接 数据 库 
mysql_query("set names utf8"):; /设置 编码 格式 
Srs = mysql_query("select * from tb_demo031 limit $ POST[text]");: /返回 结果 集 


echo'<table width="580px"><tr><td «background="pic/head.JPG">ID</td><td = background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td background="pic/head.JPG"> 日 期 </td></tr>"; 
while($rst = mysql fetch_array($rs){ 1/ 循环 输出 


?> 


<tr><td background="pic /head.JPG"><?php echo $rst[0]:?></td><td background="pic /head.JPG"><?php echo $rst[1]:7></td><td 
background="pic/head JPG"><?php echo $rst[2]:?></td><td background="pic /head.JPG"><?php echo $rst[3]:?></td></tr> 
<php 
jelsef 
echo "<script>alert( 输 入 的 不 是 一 个 数字 ');</seript>"; 
} 
} 


} 
> 
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心 法 领悟 387: limit 关键 字 的 优点 。 
Limit 关键 字 与 其 他 语句 〈 如 order by) 联合 使 用 ， 会 使 用 户 的 SQL 语句 千变万化 ， 从 而 使 程序 非常 灵活 。 


实例 388 


力 实例 说 明 


对 后 n 条 记录 的 查询 在 实际 项 目 开 发 过 程 中 也 经 常 被 用 到 ， 例 如 查询 最 后 添加 到 数据 库 中 的 n 条 信息 。 运 
行 本 实例 ， 如 图 8.57 所 示 ， 显 示 数 据 库 最 后 的 若干 数据 。 


图 8.57 ”查询 后 n 条 数据 


力 关键 技术 


与 查询 前 na 条 记录 相 比 ， 查 询 后 n 条 记录 首先 应 对 表 中 的 所 有 记录 进行 降序 排列 ， 之 后 通过 关键 字 limit 指 


定 要 查询 的 记录 个 数 。 对 记录 升序 排列 可 以 在 SQL 语句 中 添加 如 下 语句 实现 : 
order by 字段 名 (或 order by 字段 名 ase) 


对 记录 降序 排列 可 以 在 SQL 语句 中 添加 如 下 语句 实现 : 
orderby 字段 名 dese 


本 实例 实现 查询 后 n 条 数据 的 SQL 语句 如 下 : 

select * from tb_demo031 order by id desc limit $ POST[text]: 
图 设计 过 程 

编写 index.php 文件 ， 通 过 <table> 标 签 建立 网 页 架构 ， 引 入 头 部 图 片 ， 开 启 MySQL 服务 并 连接 MySQL 数 
据 库 ， 当 单 击 “ 查 看 ”按钮 时 ， 显 示 后 几 条 信息 ， 代 码 如 下 : 


if($_POST[sub){ // 单 击 “ 查 看 ”按钮 
if$_POST[text] 一 "||$_POST[text] 一 "输入 图 书 名 称 "){ // 判 断 文本 框 
echo "<script>alert( 输 入 图 书 名");</script>"; //JavaScript 提示 
Jelse{ 
iflpreg_match("/\d/".$_POST[text]){ /正则 表达 式 验证 
Sconn = mysql_connect("localhost","root"."111") or die("connect mysql false"); // 连 接 MySQL 
mysql_select_db("db_database08".$conn) or die("connect database false"): // 连 接 数据 库 
mysql_query("set names utf8"): /设置 编码 格式 


Srss = mysql_query("select * from tb_demo031 order by id desc limit $ POST[text]"): /返回 结果 集 

echo'<table width="580px"><tr><td background="pic/head.JPG">ID</td><td = background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td background="pic/head.JPG"> 日 期 </td></tr>'; 

while($rst = mysql fetch_array($rss){ /循环 输出 
> 


<tr><td background="pic /head.JPG"><?php echo $rst[0]:?></td><td background="pic /head .JPG"><?php echo $rst[1]:7></td><td 
background="pic/head JPG"><?php echo Srst[2]:?></td><td background="pic /head JPG"><?php echo $rst[3]:?></td></tr> 


PHP 开发 实例 大 全 (基础 卷 ) 


D 
jalsef 
echo "<script>alert( 输 入 的 不 是 一 个 数字 ):</script>" 
} 
} 
} 
> 


秘笈 心 法 


心 法 领悟 388: 对 SQL 语句 的 评价 。 
灵活 运用 SQL 语句 ， 会 让 用 户 觉得 很 多 看 起 来 复杂 的 程序 其 实 很 简单 。 


起 味 指教: 庚 良 雇请 
图 实例 说 明 


PHP 中 实现 分 页 显示 的 原理 就 是 从 指定 位 置 开始 显示 n 条 记录 ， 下 面 通过 本 实例 讲解 如 何 实现 这 种 显示 方 
式 。 运 行 本 实例 ， 效 果 如 图 8.58 所 示 。 


| 输入 开始 ID 


YB 开发 实战 宝典 
Java 开 发 实战 宝典 
Java Web 开 发 实战 宝 身 


8.58 ”查询 从 指定 位 置 的 n 条 记录 


力 关键 技术 
实现 从 指定 位 置 开始 查询 满足 条 件 的 n 条 记录 ， 主 要 应 用 MySQL 的 扩展 关键 字 limit， 该 关键 字 的 使 用 格 


有 

select 要 查询 的 字段 from 表 名 where 查询 的 条 件 limit 满足 条 件 的 起 始 位 置 .记录 的 个 数 

关键 字 limit 后 有 两 个 参数 ， 第 一 个 参数 用 于 指定 要 满足 条 件 记 录 的 起 始 位 置 第 二 个 参数 指定 查询 结果 中 
满足 条 件 的 记录 个 数 。 

本 实例 实现 查询 指定 位 置 的 n 条 记录 的 SQL 语句 如 下 : 

select * from tb_demo031 limit $_POST[text1], $_POST[text]: 
力 设计 过 程 

创建 index.php 文件 ， 编 写 网 页 框架 ， 开 启 MySQL 服务 器 并 连接 MySQL 数据 库 ， 当 单 击 “ 查 看 ”按钮 时 ， 
显示 指定 位 置 的 n 条 记录， 代码 如 下 : 


if($_POST[sub){ // 单 击 按钮 
// 判 断 文本 框 信息 
($1 Be |$_POST[text] 一 "输入 图 书 名 称 " || $_POST[text1] 一 "|| $_POST[text1] 一 "输入 查询 条 数 "){ 
echo "<script>alert( 输 入 图 书 名 ):</script>": //JavaScript 提示 
Jelse{ 
if(preg_mateh("/\d/".$_POST[text])){ // 正 则 表达 式 验证 
if(preg_match("/\d/",$_ POST[text1])){ // 正 则 表达 式 验 证 
$conn =mysq]_connect("localhost"."root"."111") or die("connect mysql false"): /连接 MySQL 


mysql_select_db("db_database08",$conn) or die("connect database false"): /连接 MySQL 服务 器 


第 8 章 MySQL 数据 库 与 PHP 
mysql_query("set names utf8"): // 设 置 编码 格式 
Srss = mysql_query("select * from tb_demo031 limit$ POST[text1], $ POST[text]"); // 返 回 结果 和 集 
echo'<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 
<ltd><td background="pic/head.JPG"> 价 格 </td><td background="pic/headJPG"> 日 期 </td></tr>'; 
while(Srst = mysql fetch_array($rss){ /| 循环 输出 结果 
i 
<tr><td background="pic/head.JPG"><?php echo S$rst[0]:?></td><td background="pic/head JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo S$rst[2]:?></td><td background="pic/head JPG"><?php echo $rst[3]:?></td></tr> 
<?php 
Jelse{ 
echo "<script>alert( 输 入 的 不 是 一 个 数字 "):</script>"; //JavaSeript 提示 
| 
jelsef 
echo "<script>alert( 输 入 的 不 是 一 个 数字 ");</script>"; //JavaScript 提示 
} 
} 


} 
?> 


图 秘笈 心 法 

心 法 领悟 389: 程序 运行 时 的 注意 事项 。 

本 实例 在 运行 时 ， 用 户 设 定 从 第 2 条 数据 开始 输出 ， 而 显示 数据 时 是 从 第 3 条 开始 ， 出 现 这 种 情况 的 原因 
是 数据 信息 ID 是 从 0 开始 计算 的 。 


实例 390 趣味 指数 : oobioll 


实例 说 明 


在 学 生成 绩 管理 系统 中 经 常 需要 提取 出 总 成 绩 在 前 几 名 的 学 生成 绩 信息 ， 这 就 需要 首先 对 学 生成 绩 表 中 的 
各 科 成 绩 进行 求 和 并 按 总 成 绩 进行 降序 排列 ， 最 后 利用 关键 字 limit 提取 出 前 n 条 记录 。 运 行 本 实例 ， 如 图 8.59 
所 示 ， 首 先 在 图 中 的 文本 框 中 输入 要 查询 的 记录 个 数 ， 然 后 单 击 “ 查 看 ”按钮 ， 即 可 将 满足 条 件 的 前 n 条 记录 
显示 出 来 。 


8.59 ”查询 统计 结果 中 的 前 n 条 记录 


图 关键 技术 


实现 显示 统计 结果 中 的 前 n 条 记录 ， 首 先 应 对 数据 进行 汇总 ， 然 后 按 汇 总 结果 降序 排列 ， 最 后 利用 关键 字 
limit 显示 出 指定 的 n 条 记录 ， 示 例 代码 如 下 : 

$sql=mysql_query("select *.(ywsx+wy) as total from tb_score order by (ywtsx+wy) desc limit 0.Snum "Sconn):; 

本 实例 实现 查询 统计 结果 中 前 n 条 记录 的 SQL 语句 如 下 : 


select * from tb_demo046 order by sum DESC limit $_POST[text]: 
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图 设计 过 程 
编写 index php 文件 ， 开 启 MySQL 服务 器 并 连接 MySQL 数据 库 ， 当 单 击 “查看 ”按钮 时 ， 显 示 统 计 结果 
中 的 前 n 条 记录 ， 代 码 如 下 : 


<opl 
ifS_POST[sub]){ / 单 击 “ 查 看 ”按钮 
这 $_POST[text] 一 "|| $_POST[text] 一 "输入 查询 条 数 "){ // 判 断 文 本 框 信息 
echo "<script>alert( 输 入 查询 条 数 );</script>"; /输出 JavaScript 提示 
Jelse{ 
if(preg_match("/\d/",$_POST[text]){ // 正 则 表达 式 验 证 
Sconn = mysql_connect("localhost","root","111") or die("connect mysql false"); // 连 接 MySQL 
mysql_select_db("db_database08",$conn) or die("connect database false"); // 连 接 数据 库 
mysql_query("set names utf8"); // 设 置 编 码 格式 
Srss = mysql_query("select * from tb_demo046 order by sum DESC limit $_POST[text]"); /返回 结果 集 


echo'<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 姓 名 </td><td 
background="pic/head.JPG"> 学 号 </td><td background="pic/head.JPG"> 语 文 </td><td ”background="pic/head.JPG"> 数 学 </td><td 
background="pic/head.JPG"> 英 语 </td><td background="pic/head.JPG"> 总 分 </td></tr>'; 

while($rst = mysql_fetch_array(Srss)){ // 循 环 输出 结果 


> 


<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic /head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head JPG"><?php echo $rst[2]:?></td><td background="pic/head.JPG"><?php echo $rst[3]:7></td><td 
background="pic/head.JPG"><?php echo S$rst[4];?></td><td background="pic/head.JPG"><?php echo Srst[5]}:?></td><td 
background="pic/head.JPG"><?php echo S$rst[6]:?></td></tr> 

<?php 


jelsef 
echo "<script>alert( 输入 的 不 是 一 个 数字 9:</script>": 
} 


} 


?> 


国 秘笈 心 法 


心 法 领悟 390: 通过 程序 求 和 。 


笔者 在 制作 本 实例 时 ， 并 未 对 总 分 进行 SQL 语句 的 排序 求 和 。 如 果 想 通过 程序 求 和 ， 代 码 如 下 ;: 
S$sql=mysql_query("select +,(Yw+sx+wWy) as total from tb_demo046 order by (yw+sx+wy) desc limit 


高 级 
趣味 指数 ， 寅 机 页 宙 


实例 391 


力 实例 说 明 


在 图 书 管理 系统 中 ， 经 常 需要 查询 指定 出 版 日 期 范围 内 的 图 书 情况 。 运 行 本 实例 ， 如 图 8.60 所 示 ， 首 先 在 
图 中 的 文本 框 中 输入 日 期 范围 ， 然 后 单 击 “ 查 看 ”按钮 ， 即 可 实现 查找 该 日 期 范围 内 的 所 有 图 书信 息 。 


四 Re 
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图 关键 技术 


在 SQL 语句 中 ， 对 指定 范围 内 的 数据 进行 查找 可 以 通过 以 下 两 种 方式 实现 ， 第 一 种 方式 ， 可 以 通过 关键 字 


between...and... 实 现 ， 语 法 格式 如 下 : 
select 要 查找 的 字段 from 表 名 where 字段 名 between 初始 值 and 终止 值 


第 二 种 方式 ， 可 以 通过 比较 运算 符 实现 ， 语 法 格式 如 下 : 

select 要 查找 的 字段 from 表 名 where 字段 名 > 初始 值 and 字段 名 < 终止 值 
图 设计 过 程 

创建 index.php 文件 ， 启 动 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 查 看 ”按钮 时 ， 显 示 指 定时 间 段 
的 数据 ， 代 码 如 下 : 


<?php 
这 $_POST[sub]){ / 单 击 “ 查 看 ”按钮 
1/ 判断 文本 框 信息 
这 $_POST[textl] 一 "1$ POST[textl] 一 "输入 开始 日 期 "|| $_POST[text] 一 "|| $_POST[text] 一 "输入 结束 日 期 "){ 
echo "<script>alert( 请 输入 日 期 );</script>"; //JavaScript 提示 
Jelse{ 
/验证 日 期 格式 的 正则 表达 式 


这 preg match("/([0-91{3}[1-91[0-91{2}[1-91[0-91{1}[1-91[0-91{2}[1-91r0-91{3})-((COf135781l1r0-27)-(of1-91Ir12170-91l3r01D)ICOF469111)-(of1-9Nr121[ 
0-9130))K02-(of1-91I110-912f0-8D))"$ POSTftextD) 


Sconn = mysql_connect("localhost","root","111") or die("connect mysql false"): /| 连接 MySQL 
mysql_select_db("db_database08",$conn) or die("connect database false"); /| 连接 MySQL 数据 库 
mysql_query("set names utf8"); /设置 编码 格式 

Srss =mysql_query("select * from tb_demo047 where date between '$_POST[textl] and '$ POST[text] order by date"); 
// 返 回 结果 集 


echo'<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td background="pic/head.JPG"> 日 期 </td></tr>'; 

while($rst = mysql_fetch_array($rss)){ /循环 输出 结果 
> 


<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/head.JPG"><?php echo $rst[3]:9></td></tr> 
<?php 


} 
jelsef 


echo "<script>alert( 日 期 格式 错误 ! 正确 格式 为 : xxxx-xx-xx):</script>"; //JavaScript 提示 信息 
} 
} 
> 
图 秘笈 心 法 


心 法 领悟 391: 正则 表达 式 的 限制 。 
本 实例 所 使 用 的 正则 表达 式 只 是 对 平年 ， 即 一 年 365 天 的 正则 表达 式 验证 。 


高 级 | 
实例 392 趣味 指数 :让 宙 丰 页 
实例 说 明 


在 一 些 图 书 管理 系统 中 ， 经 常 需要 按 年 、 月 、 日 查询 图 书 的 出 版 信息 。 运 行 本 实例 ， 如 图 8.61 所 示 ， 首 先 
在 图 中 的 文本 框 中 输入 要 查询 的 月 份 ， 然 后 单 击 “查找 ”按钮 ， 即 可 将 该 月 份 出 版 的 图 书信 息 查 找 出 来 。 


PHP 开发 实例 大 全 (基础 卷 ) 


DEF 1/ 尼 
入 [= 5 EERE 
书 名 价格 日 其 


C++ 开 发 实战 宝典 78 元 2010-07-11 
8 PR 范例 宝 炭 18 雹 2010-07-17 
9 则 范例 宝典 78 元 2010-07-17 
10 ppp 范 蚀 宝 下 18 雹 2010-07-17 


图 8.61 按 月 查询 统计 数据 


力 关键 技术 
本 实例 实现 按 月 查询 统计 数据 的 SQL 语句 如 下 : 


select * from tb_demo047 where month(date) ='$_POST[text1]' order by date: 
图 设计 过 程 

创建 脚本 文件 index.php， 通 过 <table> 标 签 建立 网 页 框架 ， 引 入 网 页 头 部 图 片 文 件 ， 开 启 MySQL 服务 并 连 
接 MySQL 数据 库 ， 当 单 击 “ 查 看 ”按钮 和 时， 显示 查询 信息 ， 代 码 如 下 : 


<?php 
if$_POST[sub]){ // 单 击 “ 查 看 ”按钮 
if($_POST[text1] 二 "||$_POST[text1] 一 "输入 月 份 "{ 1/ 判断 文本 框 信息 
echo "<script>alert(' 请 输入 月 份 );</script>"; /JavaScript 提示 
jslse{ 
ifpreg_match("[^A-Za-z_]/",$_POST[textl]D){f /正则 表达 式 验 证 文本 框 信息 
Sconn = mysql_connect("localhost","root","111") or die("connect mysql false"); /连接 MySQL 
mysql_select_db("db_database08",$conn) or die("connect database false"); /连接 MySQL 数据 库 
mysql_query("set names utf8"); // 设 置 编码 集 


Srss =mysql_query("select * from tb_demo047 where month(date) = '$_POST[textl] order by date"); 

echo'<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td background="pic/head.JPG"> 日 期 </td></tr>'; 

while($rst = mysql_fetch_array($rss){ // 循 环 输出 结果 
> 


<tr><td background="pic /head.JPG"><?php echo $rst[0]:?></td><td background="pic /head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo S$rst[2]:?></td><td background="pic/head.JPG"><?php echo S$rst[3]:?></td></tr> 
<?php 


} 
}else{ 

echo "<script>alert(' 月 份 格式 错误 ! 正确 格式 为 : xx');</script>"; 
} 


} 


?> 


国 秘笈 心 法 


心 法 领悟 392: 与 年 、 月 、 日 相关 的 查询 函数 。 

SQL 语言 中 提供 了 如 下 函数 ， 利 用 这 些 函数 可 以 很 方便 地 实现 按 年 、 月 、 日 进行 查询 。 
回 ”year(data): 该 函数 用 于 返回 日 期 表达 式 data 中 的 公元 年 份 所 对 应 的 数值 。 
month(data): 该 函数 用 于 返回 日 期 表达 式 data 中 的 月 份 所 对 应 的 数值 。 

回 ”day(data): 该 函数 用 于 返回 日 期 表达 式 data 中 的 日 期 所 对 应 的 数值 。 
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趣味 指教: 认真 丰 评 : 


力 实例 说 明 


对 信息 进行 查询 时 ， 有 时 需要 查询 大 于 某 数 值 的 所 有 记录 ， 例 如 在 图 书 管理 系统 中 ， 有 时 需要 查询 价格 大 
于 某 一 值 的 图 书 的 详细 信息 。 运 行 本 实例 ， 如 图 8.62 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 查询 的 图 书 价格 ， 然 后 
单 击 “ 查 看 ”按钮 ， 即 可 将 图 书 表 中 大 于 该 数值 的 图 书信 息 查找 出 来 。 


PRP 开 发 实 成 宝 内 
2 开发 实 碾 宇 下 


图 8.62 查询 大 于 指定 条 件 的 记录 


图 关键 技术 


实现 查找 大 于 某 条 件 的 商品 信息 ， 只 需 在 SQL 语句 的 关键 字 后 用 运算 符 “>” 进 行 限制 ， 例 如 本 实例 中 实 
现 查找 大 于 一 定价 格 的 图 书信 息 的 代码 如 下 : 

select * from tb_demo047 where price > $_ POST[text1] order by price: 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 查 看 ”按钮 时 ， 显 示 满 足 条 
件 的 信息 ， 代 码 如 下 : 


<?php 
if$_POST[sub]){ // 单 击 “ 查 看 ”按钮 
这 $_ POST[textl] 一 "||$_POST[text1] 一 "输入 价格 "){ // 判 断 文 本 框 信息 
echo "<script>alert(' 请 输入 价格 );</script>"; //JavaScript 提示 
Jelse{ 
if(preg_match("/[^A-Za-z_]/".$_POST[text1]){ // 正 则 表达 式 
Sconn = mysql_connect("localhost","root","111") or die("connect mysql false"); /连接 MySQL 
mysql_select_db("db_database08",Sconn) or die("connect database false"); // 连 接 MySQL 数据 库 
mysql_query("set names utf8"); // 设 置 编码 格式 


S$rss = mysql_query("select + from tb_demo047 where price > $_POST[text1] order by price"): 

echo'<table width="580px"><tr><td "background="pic /head.JPG">ID</td><td -background="pic/head.JPG"> 书 名 </td><td 
background="pic/head.JPG"> 价 格 </td><td background="pic/head.JPG"> 日 期 </td></tr>': 

while($rst = mysql_fetch_array(Srss)){ /| 循环 输出 结果 
> 


<tr><td background="pic /head.JPG"><?php echo $rst[0]:?></td><td background="pic /head.JPG"><?php echo $rst[1]:7></td><td 
background="pic/head JPG"><?php echo $rst[2]:?></td><td background="pic /head. JPG"><?php echo $rst[3]:?></td></tr> 
<php 


} 
jslsef 

echo "<script>alert( 不 是 正确 的 数值 );</script>"; /输出 提示 
) 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


心 法 领悟 393: 另外 一 种 实现 方式 。 
实现 本 实例 的 SQL 语句 代码 还 可 以 使 用 另外 一 种 方式 来 表达 ， 代 码 如 下 : 


select * from tb_demo047 where price !<$ POST[textl] order by price; 

复 记录 级 | 
实例 

| a 


力 实例 说 明 


在 某 些 管理 系统 中 ， 有 重复 记录 是 不 可 避免 的 ， 不 在 前 台 显示 重复 的 记录 可 以 通过 SQL 语言 的 关键 字 
distinct 实现 。 运 行 本 实例 ， 如 图 8.63 所 示 ， 图 书信 息 中 价格 相同 的 信息 将 被 删除 。 


查询 结果 不 显示 重 笃 记录 


ET 
十 名 

PHP 开 复 实 或 室 瑞 

6 开发 实 引 主 突 


图 8.63 去 掉 重复 项 输出 


图 关键 技术 


SQL 语句 中 ， 查 询 结 i distinct 实现 ， 该 关键 字 使 用 的 格式 如 下 : 
select distinct 字段 名 from 表 名 where 查询 条 


distinct 闫 负 字 可 以 在 查询 结果 中 去 除 重复 和 ， 与 其 对 应 的 还 有 关键 字 all。 在 SQL 语句 中 加 入 关键 字 all， 
表示 显示 所 有 的 记录 ， 如 果 在 SQL 语句 中 这 两 个 关键 字 都 不 加 ， 则 查询 结果 将 显示 所 有 的 记录 。 


力 设计 过 程 
创建 脚本 文件 index.php， 开 启 MySQL 服务 器 并 连接 MySQL 数据 库 ， 单 击 按钮 显示 信息 ， 核 心 代码 如 下 : 
人 if($_POST[submit){ / 单 击 按钮 
这 $_POST[text] != "|| $_POST[text] != "输入 图 书 价格 "){ // 判 断 文本 框 信息 
if(preg_match("/[^a-zA-Z_]".$_POST[text)){ // 正 则 表达 式 验证 信息 
// 返 回 结果 集 


Srs = mysql_query("select distinet * from tb_demo031 where price ='$_POST[text] 元 "); 
> 
<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 书 名 </td><td background="pic/head.JPG"> 价 格 
</td><td background="pic/head.JPG"> 日 期 </td></tr> 
<?php 
> 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/head.JPG"><?php echo $rst[3]:?></td></tr> 


<Iphp 


while(Srst = mysql fetch_row($rs){ /循环 输出 结果 


} 
Jelse{ 
echo "<script>alert( 输 入 不 是 一 个 数值 ):</script>": /JavaScript 提示 
} 
Jelse{ 
echo "<script>alert(' 请 输入 信息 "):</script>": //JavaScript 提示 
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} 


. 
> 


秘笈 心 法 


心 法 领悟 394: 使 用 关键 字 distinet 的 注意 事项 。 
SQL 语句 中 的 关键 字 distinct 必须 与 where 子 句 联合 使 用 ， 否 则 输出 的 信息 不 会 有 变化 。 


件 的 查询 | 
| 


趣味 指数 : ta 


实例 395 


力 实例 说 明 
在 开发 一 些 网 站 时 ， 有 时 需要 查找 不 满足 一 定 条 件 的 所 有 记录 ， 比 如 在 人 事 系 统 中 查找 所 有 不 姓 刘 的 员工 


信息 。 运 行 本 实例 ， 如 图 8.64 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 不 想 显示 的 图 书 名 称 ， 然 后 单 击 “ 查 看 ”按钮 ， 
即 可 将 所 有 不 是 该 名 称 的 图 书 显示 出 来 。 


| AR AR AR | 
mot 与 谓词 进行 组 宫 条 代 的 棕 询 
ss 
TB 于 夏 实 成 宣 下 
Java 开发 实战 宝典 
Tava Teb 开 复 实 厂家 下 
,NET 开发 实 成 宣 窒 


3 开发 实 戌 主 突 
C+ 开发 实 访 室 冉 


3 区 他 主 天 


8.64 not 与 谓词 进行 组 合 条 件 查询 


力 关键 技术 


not 与 谓词 进行 组 合 所 形成 的 表达 式 分 别 是 not between.….and...、is not null 和 not mn， 这 3 种 组 合 的 详细 说 明 
如 下 : 


(1) not between...and... 
where 字段 名 not between 查询 范围 开始 值 and 查询 范围 的 结束 值 


该 式 查询 所 有 不 在 该 范围 内 的 记录 ， 这 种 限定 条 件 可 以 改写 成 如 下 格式 : 
where 字段 名 < 查询 范围 的 开始 值 and 字段 名 > 查询 范围 的 结束 值 


(2) is not null 

该 式 根据 所 使 用 的 关键 字 指 定 对 空 值 或 非 空 值 的 搜索 ,如 果 有 任何 操作 数 是 NULL, 则 表达 式 取 数 为 NULL。 

(3) not in 

该 式 根据 使 用 的 关键 字 是 包含 在 列表 内 还 是 排除 在 列表 外 ， 指 定 表达 式 的 搜索 ， 搜 索 表达 式 可 以 是 常量 或 
列 名 ， 而 列 名 可 以 是 一 组 常量 ， 但 更 多 情况 下 是 子 查 询 。 


图 设计 过 程 
编写 index.php 文件 。 在 文本 框 中 输入 内 容 后 单 击 “ 查 看 ”按钮 输出 显示 信息 ， 代 码 如 下 : 
2 =mysql_connect("localhost"."root","111") or die("connect mysql false"): /连接 MySQL 
mysql_select_db("db_database08".$conn) or die ("connect database false"): // 连 接 数 据 库 


mysql_query("set names utf8"); /设置 编码 格式 


PHP 开发 实例 大 全 (基础 卷 ) 


if($_POST[sub){ / 单 击 按钮 
这 $_ POST[text] =" || $_POST[text] != "输入 图 书 名 称 "){ 1/ 判断 文本 框 信息 
ifpreg_match("[^0-9 ]".$ POST[textD){ /正则 表达 式 验证 


Srs = mysql_query("select * from tb_demo031 where bname not like %S$_ POST[text]o"): /返回 结果 集 
Ce 
<table width="580px"><tr><td background="pic/head JPG">ID</td><td background="pic/head JPG"> 书 名 </td><td background="pic/head.JPG"> 价 格 
</td><td background="pic/head.JPG"> 日 期 </td></tr> 
<?php 

while(Srst = mysql fetch_row($rs){ /循环 输出 结果 

?> 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/head.JPG"><?php echo $rst[3]:?></td></tr> 


<Iphp 
Jelse{ 
echo "<script>alert( 输 入 名 称 错误 ):</script>": /DavaSeript 提示 
Jelse{ 
echo "<script>alert( 请 输入 信息 ");</script>"; //JavaScript 提示 
} 
} 
> 
图 秘笈 心 法 


心 法 领悟 395: 对 谓词 not 的 理解 。 
用 户 可 以 将 本 实例 简单 理解 为 ， 在 谓词 前 添加 not 关键 字 ， 表 示 不 在 某 个 范围 或 不 等 于 某 个 值 。 


实 重复 记录 和 记录 条 数 高 级 | 
9 趣味 指数 : lolol 
实例 说 明 


在 户籍 管理 系统 中 ， 会 经 常用 到 查询 同名 住户 的 模块 。 运 行 本 实例 ， 如 图 8.65 所 示 ， 首 先 在 图 中 的 文本 框 
中 输入 要 查询 的 同名 图 书 名 称 ， 然 后 单 击 “ 查 看 ”按钮 ， 即 可 将 要 查找 的 同名 图 书 总 数 显示 出 来 。 


图 8.65 显示 重复 数据 及 重复 数量 


力 关键 技术 


count0 函 数 的 参数 为 表 中 某 字 段 的 名 称 或 *， 例 如 求 某 表 的 所 有 字段 数 应 按 如 下 格式 进行 : 
select count(y) as 新 字段 名 from 表 名 where 查询 条 件 


本 实例 实现 显示 数据 中 重复 记录 和 记录 条 数 的 SQL 语句 如 下 : 


select count(*) from tb_demo031 where bname = $_POST[text]: 
图 设计 过 程 
创建 脚本 文件 index.php， 开 启 MySQL 服务 器 并 连接 数据 库 ， 当 单 击 “ 查 看 全 部 ”按钮 时 ， 显 示 数 据 库 中 
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的 所 有 信息 。 当 在 文本 框 中 输入 图 书 名 称 并 单 击 “ 查 看 ”按钮 时 ， 显 示 如 图 8.65 所 示 信 息 ， 核 心 代码 如 下 : 
<?php 


ifS_POST[sub]){ / 单 击 “ 查 看 ”按钮 
iRS_POST[text] !="" || $_POST[text] != "输入 图 书 名 称 "){ // 判 断 文 本 框 信息 
ifpreg_match("["0-9 ]".$_ POST[textD){ // 正 则 表达 式 验证 信息 
Srs = mysql_query("select count(*) from tb_demo031 where bname ='$_POST[text]"); /返回 结果 集 


> 
<table width="580px"><tr><td background="pic/head.JPG"> 图 书 名 称 </td><td background="pic/head.JPG"> 重 复数 值 </td></tr> 
php 

Srst =mysql fetch_row($rs); /结果 


> 
<tr><td background="pic/head. JPG"><?php echo " 《".$_POST[text].") ":?></td><td background="pic/head.JPG"><?php ccho S$rst[0]:?></td></tr> 


<?php 
jelsef 


echo "<script>alert( 输 入 名 称 错误 ):</script>": //JavaScript 提示 
Yelse{ 
echo "<script>alert(' 请 输入 信息 ”);</script>"; //JavaScript 提示 
} 
| 
> 
国 秘笈 心 法 


心 法 领悟 396: 分 组 语句 group by。 
本 实例 还 可 以 通过 分 组 语句 group by 实现 ，SQL 语句 的 代码 如 下 : 


select bname,count(*) as total from tb_demo031 where bname='$_POST[text] group by name; 


力 实例 说 明 


在 一 些 电子 商务 类 网 站 中 ， 将 商品 按 添 加 时 间 降 序 排列 并 在 前 台 页 面 中 进行 显示 ， 可 以 将 最 新 的 商品 信息 
显示 在 网 站 的 前 面 。 运 行 本 实例 ， 如 图 8.66 所 示 ， 单 击 图 中 的 “降序 ”按钮 ， 即 可 实现 将 图 中 的 所 有 商品 信息 
降序 输出 。 


Ee 


Nina 食 食 食 食 


图 8.66 商品 信息 降序 查询 


图 关键 技术 


SQL 语言 中 ， 对 查询 结果 按 某 字段 进行 排序 可 以 通过 order by 子 句 实现 ， 如 果 按 某 字 段 进行 升序 排列 可 以 


利用 关键 字 asc 或 不 加 任何 关键 字 ， 例 如 : 
select 字段 名 from 表 名 where 查询 条 件 order by 指定 的 字段 名 (asc) 


按 某 字段 进行 降序 排列 ， 可 以 利用 关键 字 desc， 例 如 : 


PHP 开发 实例 大 全 (基础 卷 ) 


select 字段 名 ftom 表 名 where 查询 条 件 order by 指定 的 字段 名 desc 
本 实例 实现 降序 查询 商品 信息 的 SQL 语句 如 下 : 


select * from tb _demo053 order by id desc: 
图 设计 过 程 

创建 脚本 文件 index.php。 当 单 击 “ 查 看 ”按钮 时 ， 正 常 输出 商品 信息 ; 当 单 击 “ 降 序 ” 按 钮 时 ， 显 示 结果 
如 图 8.66 所 示 ， 核 心 代码 如 下 : 


<?php 
if($_POST[sub) { / 单 击 按钮 
Srs = mysql_query("select * from tb_demo053 order by id dese"); /返回 结果 集 
> 
<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 商 品 </td><td background="pic/head.JPG"> 价 格 
<ltd><td background="pic/head.JPG"> 日 期 <ltd></tr> 
<2pl 


hp 
while($rst = mysql_fetch_row($rs)){ 1/ 循环 输出 结果 
?> 


<tr><td background="pic/head.JPG"><?php echo $rst[01:?></td><td background="pic/head.JPG"><?php echo S$rst[11:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/head.JPG"><?php echo S$rst[0]:?></td></tr> 
<Iphp 


} 
} 
> 
秘笈 心 法 


心 法 领悟 397: SQL 语句 如 何 设置 排列 方式 为 升序 。 
默认 情况 下 ，SQL 语句 是 以 升序 排列 的 ， 如 果 想 利用 代码 实现 升序 排列 ， 可 以 使 用 关键 字 asc。 以 本 实例 为 
例 ，SQL 语句 如 下 : 


select * from tb_demo053 order by id asc; 


| ~ 
趣味 指数 : 请 坑 请 计 | 
力 实例 说 明 


在 实际 项 目 开发 过 程 中 ， 数 据 库 中 的 信息 在 前 台 显示 时 大 多 数 情况 下 不 仅 是 按 某 一 个 字段 进行 排序 ， 而 是 
按 多 个 字段 共同 限制 记录 排序 输出 的 。 运 行 本 实例 ， 如 图 8.67 所 示 ， 单 击 图 中 的 “排序 ”按钮 ， 即 可 实现 所 有 
商品 信息 先 按 商 品 数 量 降序 排列 ， 然 后 按 单价 进行 升序 输出 。 


人 商品 数量 价格 日 期 

3 电 风 局 20 ?00 2010-07-21 
2 | 裕 波 炉 15 1300 2010-07-21 
1 电 宰 1 [2500 2010-07-21 
四 全 自动 洗衣 机 0 3500 20002 
6 笔 沁 本 电脑 日 3000 2010-07-21 
9 空调 了 5000 2010-07-21 


8.67 对 数据 进行 多 条 件 排序 


力 关键 技术 
对 记录 进行 升序 排列 可 以 在 SQL 语句 的 order by 子 句 中 指定 关键 字 ase 或 不 加 任何 关键 字 ， 对 记录 进行 降 
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序 排列 可 以 在 SQL 语句 的 order by 子 句 中 指定 关键 字 desc。 实 现 多 条 件 查 询 也 是 通过 order by 子 句 实现 的 ， 只 
是 多 个 限定 条 件 之 间 应 用 逗号 进行 分 隔 ， 例 如 : 

select 字段 名 from 表 名 where 查询 条 件 order by 字段 1 asc, 字段 2 desc… 
图 设计 过 程 

创建 脚本 文件 index.php。 编 写 网 页 框架 ， 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 单 击 “ 排 序 ” 按 钮 
时 ， 显 示 对 数据 进行 多 条 件 排序 ， 代 码 如 下 : 

A?php 


$conn = mysql_connect("localhost","root","111") or die("connect mysql false"); /连接 MySQL 
mysql_select_db("db_database08",$conn) or die ("connect database false"); // 连 接 数据 库 
mysql_query("set names utf8"); // 设 置 编码 格式 
if$_POST[sub]){ / 单 击 按钮 

Srs = mysql_query("select * from tb_demo054 order by mount desc.price ase"); /返回 结果 集 
> 


<table width="S80px"><tr><td back ground="pic /head JPG">ID</td><td background="piclhead JPG"> 商 品 <hd><td background="piclhead JPG"> 数 量 
<ltd><td background="pic/head.JPG"> 价 格 <ltd><td background="pic/head.JPG"> 日 期 <ltd></tr> 
<Iphp 

while($rst = mysql_feteh_row(Srs)){ /| 循环 输出 结果 
?> 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo Srst[1]:2></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic /head.JPG"><?php echo $rst[3]:?></td><td 
background="pic/head.JPG"><?php echo Srst[4]:?></td></tr> 
<?php 

} 


} 
> 


国 秘笈 心 法 


心 法 领悟 398: 使 用 多 条 件 排序 的 注意 事项 。 
对 查询 信息 进行 多 条 件 排序 是 为 了 共同 限制 记录 的 排序 输出 ， 一 般 情况 下 ， 由 于 不 是 单一 条 件 限制 ， 所 以 
在 输出 效果 上 有 一 些 差别 。 


[ou 4 蜀 高 级 | 
图 实例 说 明 


在 商品 信息 管理 系统 中 ， 经 常 需要 对 商品 的 价格 、 数 量 进行 求 和 ， 然 后 根据 所 求 得 的 值 对 商品 进行 排序 ， 
从 而 实现 商品 的 排序 输出 。 运 行 本 实例 ， 分 别 如 图 8.68 所 示 ， 将 单一 类 型 商品 求 和 并 按 商品 数量 和 商品 单价 
排序 。 


志 福 EN LL Le 3000 
BE 5 图， | 溃 TO me 
ED IEE I 4000 
[ 刁 丰 Bm nm hnrora EL 


图 8.68 ”对 统计 结果 进行 排序 


PHP 开发 实例 大 全 (基础 卷 ) 


图 关键 技术 


SQL 语言 中 ， 对 某 字段 所 有 数据 求 和 可 以 通过 函数 sam0 实 现 ， 该 函数 的 使 用 格式 如 下 : 
sum([a 由 字段 名 ) 或 sum([distinct] 字 段 名 ) 


sum() 函 数 中 的 参数 如 果 为 all 加 字段 名 , 则 表示 对 该 字段 中 的 所 有 记录 进行 求 和 , 包括 重复 记录 ; 如 果 sum0 
函数 中 的 参数 为 distinct 加 字段 名 ， 则 表示 对 该 字段 的 所 有 不 重复 记录 进行 求 和 。 在 select 语句 中 使 用 sum0 函 


数 的 格式 如 下 : 
select sum( 字 段 名 ) as 新 字段 名 fom 表 名 where 查询 条 件 


本 实例 实现 对 统计 结果 排序 的 SQL 语句 如 下 : 

select * from tb_demo054 order by mount desc.price asc: 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 排 序 ” 按 钮 时 ， 显 示 运 行 结 
果 ， 如 图 8.68 所 示 ， 其 代码 如 下 : 


<?php 
S$conn = mysql_connect("localhost","root","111") or die("connect mysql false"); // 连 接 MySQL 
mysql_select_db("db_database08",$conn) or die ("connect database false"); // 连 接 MySQL 数据 库 
mysql_query("set names utf8"): /设置 编码 格式 
if($_POST[sub){ / 单 击 按钮 

Srs = mysql_query("select * from tb_demo054 order by mount desc.price ase"); // 返 回 结 果 集 
> 


<table width="580pxr><tt><td background="pic/head JPG">ID</td><td background="pic/head JPG"> 商 品 <hd><td background="piec/head .JPG"> 数 量 
</td><td background="pic/head.JPG"> 价 格 </td><td background="pic/head.JPG"> 日 期 </td><td background="pic/head.JPG"> 总 价值 </td></tr> 
<?php 

while($rst = mysql_fetch_row($rs){ /循环 输出 结果 
> 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?> 件 </td><td background="pic/head.JPG"><?php echo $rst[3]:?> 元 </td><td 
background="pic/head.JPG"><?php echo Srst[4]:?><td background="pic/head.JPG"><?php echo S$rst[2]*$rst[3]:?> 元 </td></td></tr> 
<?php 

} 
} 


国 秘笈 心 法 


心 法 领悟 399， 求 和 函数 。 
在 对 数据 库 中 的 数据 进行 计算 时 会 经 常用 到 求 和 函数 ， 使 用 该 函数 可 以 免 去 手动 计算 某 些 数据 的 麻烦 ， 同 
时 也 提高 了 计算 的 效率 和 准确 性 。 


高 级 
趣味 指数 : 让 让 宙 穴 


实例 400 


力 实例 说 明 


在 动态 网 站 开发 过 程 中 ， 经 常 要 求 把 某 一 字段 的 内 容 按照 一 定 的 规定 进行 分 组 ， 然 后 将 分 组 后 的 结果 按 某 
一 字段 进行 统计 求 和 ， 最 终 得 到 查询 结果 。 运 行 本 实例 ， 如 图 8.69 所 示 ， 单 击 图 中 的 “排序 ”按钮 ， 即 可 实现 
先 对 表 中 的 所 有 商品 的 单价 与 数量 进行 求 和 ， 然 后 按 商 品 ID 进行 统计 。 
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图 8.69 单列 数据 分 组 统计 


图 关键 技术 


实现 单列 数据 的 分 组 统计 ， 首 先 需要 根据 某 字段 进行 分 组 ， 然 后 对 分 组 结果 进行 统计 ， 本 实例 中 实现 单列 
数据 分 组 统计 的 代码 如 下 : 

select id,name,sum(price)as title ,date from tb_demo054 group by id order by title dese; 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 排 序 ” 按 钮 时 ， 显 示 单 列 数 
据 分 组 统计 结果 ， 如 图 8.69 所 示 ， 代 码 如 下 : 


<?php 
$conn = mysql_connect("localhost", "root","111") or die("connect mysql false"); /连接 MySQL 
mysql_select_db("db_database08",$conn) or die ("connect database false"); // 连 接 MySQL 数据 库 
mysql_query("set names utf8"); // 设 置 编码 集 
if($_POST[sub){ // 单 击 按钮 

Srs = mysql_query("select id,name,sum(price)as title ,date from tb_demo054 group by id order by title desc"); /| 返回 结果 集 


<table width="580px"><tr><td background="pic/head JPG">ID</td><td background="pic/head JPG'> 商 品 <d><td background="pic/head .JPG'> 总 额 
<ltd><td background="pic/head.JPG"> 日 期 <td></tr> 
<?php 

while(Srst = mysql_feteh_row($rs){ // 循 环 输出 结果 


2> 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2];?> 元 </td><td background="pic/head JPG"><?php echo S$rst[3];?></td></tr> 
<?php 

} 
} 


?> 
力 秘笈 心 法 
心 法 领悟 400: 使 用 分 组 语句 的 注意 事项 。 


当 分 组 语句 group by 和 排序 语句 order by 同时 出 现在 SQL 语句 中 时 ,要 将 分 组 语句 书写 在 排序 语句 的 前 面 ， 
否则 会 出 现 如 图 8.70 所 示 的 错误 。 


A Ee et de er. 


图 8.70 将 oy 书写 在 pp yh 前 面 


高 级 : 
|S 娘娘 让 人 女 二 


力 实例 说 明 
对 商品 销售 结果 进行 统计 时 ,经 常 需要 按 商品 销售 表 中 的 多 列 进行 分 组 统计 。 运 行 本 实例 , 如 图 8.71 所 示 ， 
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PHP 开发 实例 大 全 (基础 卷 ) 
单 击 图 中 的 “排序 ”按钮 ， 即 可 将 商品 销售 表 中 的 所 有 同名 商品 按 销 售 数量 和 单价 求 和 并 显示 统计 结果 。 


Ll] 


图 8.71 多 列 数据 分 组 统计 


力 关键 技术 


多 列 数据 的 分 组 统计 与 单列 数据 的 分 组 统计 实现 方式 类 似 ， 只 是 按 多 个 字段 进行 分 组 统计 时 ， 统 计 字段 之 


间 需 用 逗号 进行 分 隔 ， 例 如 : 
selecty, sum( 字 段 1) as 新 字段 1 from 表 名 group by 字段 名 where 查询 条 件 


本 实例 中 实现 多 列 数据 分 组 统计 的 代码 如 下 : 

select *,sum(pircetmount) as title from tb_demo054 group by id order by title desc: 
图 设计 过 程 

编写 index.php 文件 ， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 排 序 ”按钮 时 ， 显 示 如 图 8.71 所 
示 的 内 容 ， 代 码 如 下 : 


< 

3 =mysql_connect("localhost","root","111") or die("connect mysql false"); // 连 接 MySQL 
mysql_select_db("db_database08",$conn) or die ("connect database false"); /| 连接 MySQL 数据 库 
mysql_query("set names utf8"); 1/ 设置 编码 格式 
if($_POST[sub){ // 单 击 按钮 


Srs = mysql_query("select id.name.sum(price+mount)as title .date from tb_demo054 group by id order by title desc "); // 返 回 结果 集 
?> 
<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head JPG"> 商 品 </td><td background="pic/head.JPG"> 总 额 
</td><td background="pic/head.JPG"> 日 期 <ltd></tr> 
<?php 
while(Srst = mysql_fetch_row(Srs)){ /循环 输出 结果 


?> 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo Srst[1];?><htd><td 
background="pic/head JPG"><?php echo Srst[2]:?> 元 </td><td background="pic/head.JPG"><?php echo $rst[3]:2></td></tr> 
<Iphp 

} 
| 


> 


图 秘笈 心 法 


心 法 领悟 401: 使 用 group by 语句 的 注意 事项 。 
group by 语句 后 面 一 般 为 不 是 聚合 函数 的 数列 ， 即 不 是 要 分 组 的 列 。 


i 


实例 402 趣味 指数 : 妇女 太太 
图 实例 说 明 


开发 一 个 大 型 的 服务 类 网 站 ， 经 常 需要 建立 多 张 表 ， 并 且 表 与 表 之 间 通 过 某 种 关系 建立 关联 。 运 行 本 实例 ， 
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如 图 8.72 所 示 ， 单 击 图 中 的 “分 组 统计 ”按钮 ， 即 可 将 两 张 商品 信息 表 中 的 平均 价格 统计 出 来 。 


《ASP.RET 纺 程 宝 夫 》 3 0 元 


图 8.72 分 组 统计 结果 


图 关键 技术 


实现 多 表 分 组 统计 ， 需 要 在 多 个 表 之 间 建 立 关 联 ， 然 后 分 别 对 相互 关联 的 表 进 行 分 组 统计 ， 例 如 可 以 按 如 
下 格式 建立 多 个 表 之 间 的 关联 : 

select sum( 表 1. 表 1 中 某 字段 ) as 新 字段 名 1.sum( 表 2. 表 2 中 某 字段 名 ) as 新 字段 名 2...from 表 1, 表 2...where 表 1. 关 联 字段 = 表 2. 关 联 字段 … 

group by 某 字 段 

本 实例 中 通过 如 下 代码 实现 多 表 分 组 统计 : 

select a.name, AVG(a.price).b.name, AVG(b.price) from tb_demo058_1 as atb_demo058 as b where aid =b.id group by b.type; 
力 设计 过 程 

创建 脚本 文件 index.php。 单 击 “PHP 表 数 据 ” 按 钮 ， 循 环 输出 数据 表 tb_demo058_1 中 的 所 有 信息 ， 单 击 
“ASPNET 表 数 据 ” 按 钮 ， 循 环 输出 数据 表 tb_demo058 中 的 所 有 信息 。 当 单 击 “ 分 组 统计 ”按钮 时 ， 联 合 两 
张 表 数据 ， 输 出 两 张 表 图 书 商 品 价格 的 平均 值 ， 核 心 代码 如 下 : 


<2php 
if($_GET[page] — "3"){ // 当 地 址 栏 参数 page 等 于 3 
// 两 表 查 询 的 SQL 语句 
$sql = "select a.name, AVG(a.price).b.name, AVG(b.price) from tb_demo058_1 as a.tb_demo058 asb where a.id =b.id group by b.type"; 
Srs = mysql_query($sql); // 返 回 结果 集 
> 
<table width="580px"><tr><td background="pic/head.JPG"> 图 书 名 称 </td><td background="pic/head.JPG"> 平 均 售 价 </td></tr> 
<?php 
Srst = mysql_fetch_row($rs); /| 输出 结果 


<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:?> 元 
</td></tr><tr><td background="pic/head.JPG"><?php echo Srst[2]:?></td><td background="pic/head. JPG"><?php echo $rst[3]:?> 元 </td></tr> 
<Iphp 


国 秘笈 心 法 


心 法 领悟 402: 对 多 表 查 询 的 理解 。 
多 表 联 合 查询 是 数据 库 应 用 技术 的 重要 体现 ， 也 是 操作 数据 库 重要 且 相 对 较 复杂 的 知识 。 


实例 403 高 级 


起 叶 指示 :机 宙 页 太 
力 实例 说 明 


在 学 生成 绩 管理 系统 中 ， 经 常 需要 求 出 班级 内 所 有 学 生 的 各 科 成 绩 总 和 ， 从 而 求 出 学 生 的 平均 成 绩 。 和 运行 
本 实例 ， 如 图 8.73 所 示 ， 单 击 图 中 的 “对 学 生成 绩 汇总 ”按钮 ， 即 可 将 班级 内 学 生 的 各 科 成 绩 统计 出 来 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


8.73 ”对 学 生成 绩 汇总 


图 关键 技术 


SQL 语句 中 ， 对 某 字段 的 所 有 记录 进行 求 和 可 以 通过 函数 sum0 实 现 ， 该 函数 的 使 用 方法 如 下 : 

et 

参数 说 明 ; 

all: 表示 对 指定 字段 的 所 有 值 进行 聚集 函数 运算 ，all 为 默认 值 ， 如 果 不 加 参数 all 或 distinct， 则 表示 对 指 
定 字段 的 所 有 记录 进行 聚集 运算 。 

distinct; 表示 对 指定 字段 的 所 有 非 重复 记录 进行 求 和 。 

expression: 是 精确 数字 或 近似 数字 数据 类 型 分 类 (bit 数据 类 型 除外 ) 的 表达 式 。 

sum0) 函 数 的 返回 类 型 如 表 8.3 所 示 。 


表 8.3 sum() 函 数 的 返回 类 型 


decimal(38.s) 除 以 decimal(10.0) 


money 和 smallmoney 分 类 
float 和 real 分 类 


图 设计 过 程 

编写 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 单 击 “ 对 学 生成 绩 汇 总 ”按钮 时 ， 
显示 如 图 8.73 所 示 的 信息 ， 核 心 代码 如 下 : 

<zphp 


$conn = mysql_connect("localhost", "root","111") or die ("connect mysql false"): /| 连接 MySQL 
mysql_select_db("db_database08".$conn) or die ("connect database false"): /| 连接 MySQL 数据 库 
mysql_query("set names utf8"):; 1/ 设置 编码 格式 
if($_GET[page] =— "1"){ //page 等 于 1 时 


Srss = mysql_query("select *,sum(chineset+math+english) as a from tb_demo059 group by name order by a dese "); ”// 返 回 结果 集 

?> 
<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 学 生 姓 名 </td><td background="pic/head.JPG"> 
语文 成 绩 </td><td background="pic/head.JPG"> 数 学 成 绩 </td><td background="pic/head.JPG"> 英 语 成 绩 </td><td background="pic/head.JPG"> 总 成 
绩 </td></tr> 
<?php 

while($rst = mysql_fetch_row($rss){ 1/ 循环 输出 结果 
> 

<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/head. JPG"><?php echo $rst[3]:?></td><td 
background="pic/head.JPG"><?php echo S$rst[4]:?></td><td background="pic/head. JPG"><?php echo $rst[5]?></td></tr> 
<?php 


} 
此 


> 


国 秘笈 心 法 
心 法 领悟 403: 对 求 和 函数 sum0 的 理解 。 
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sum0 函 数 主 要 用 于 对 数据 表 字 段 求 和 ， 一 般 与 分 组 函数 联合 使 用 ， 但 是 只 有 出 现在 多 表 查 询 之 中 才能 真正 
体现 出 它 的 优势 。 


: 


实例 404 趣味 指数 ， 雄 友 志雄 ， 
实例 说 明 


获取 统计 数据 平均 值 的 方法 有 多 种 ， 例 如 可 以 先 求 得 所 有 数据 的 总 和 ， 然 后 再 除 以 总 个 数 ， 而 SQL 语言 中 
提供 了 专门 求 平均 数 的 函数 avg0。 本 实例 将 利用 该 函数 求 得 学 生成 绩 表 中 各 科 成 绩 的 平均 值 。 运 行 本 实例 ， 如 
8.74 所 示 ， 单 击 图 中 “对 学 生成 绩 汇总 ”按钮 ， 即 可 将 各 科 的 平均 成 绩 显示 出 来 。 


avE 


志和 4 


图 8.74 ”取得 学 生 的 各 科 平 均 成 绩 


力 关键 技术 
获取 某 字段 的 所 有 记录 的 平均 值 ， 可 以 通过 函数 avg0 实 现 ， 该 函数 的 使 用 方法 如 下 : 


avg([all | distinct] expression) 

本 实例 实现 利用 avg0 函 数 实现 显示 平均 成 绩 的 SQL 语句 如 下 : 

select avg(chinese).avg(math),avg(english) from tb_demo059: 
图 设计 过 程 

创建 脚本 文件 index.php。 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 单 击 “ 对 学 生成 绩 汇总 ”按钮 时 ， 
显示 如 图 8.74 所 示 的 内 容 。 实 现 此 功能 的 核心 代码 如 下 : 

<?php 


Sconn = mysql_connect("localhost","root","111") or die ("connect mysql false"): // 连 接 MySQL 

mysql_select_db("db_database08",Sconn) or die ("connect database false"); // 连 接 MySQL 数据 库 

mysql_query("set names utf8"); /设置 编码 集 

if($_GET[page] — "1"){ // 如 果 page 等 于 1 
Srss = mysql_query("select * from tb_demo059"); // 返 回 结果 集 

> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 学 生 姓名 </td><td background="pic/head.JPG"> 
语文 成 绩 </td><td background="pic/head.JPG"> 数 学 成 绩 </td><td background="pic/head.JPG"> 英 语 成 绩 </td></tr> 


while($rst = mysql fetch_row($rss){ /循环 输出 结果 


<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:2></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic /head. JPG"><?php echo $rst[3]:?></td><td 
background="pic/head.JPG"><?php echo $rst[4]:?></td></tr> 

<?php 


} 

Srts = mysql_query("select aveg(chinese).avg(math).avg(english) from tb_demo059");: // 返 回 结果 集 

Srsth = mysql_fetch_row(Srts): 
> 
<tr><td background="pic/head.JPG"> 各 科 平 均 成 绩 </td><td background="pic/head.JPG"></td><td background="pic/head.JPG"><?php echo 
Srsth[0]:?> </td><td background="pic/head.JPG"><?php echo S$rsth[1]:?></td><td background="pic/head.JPG"><?php echo S$rsth[1]:?></td></tr> 
<?php 
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} 
> 


心 法 领悟 404: 格式 化 函数 number formate0 的 使 用 。 


本 实例 并 没有 对 平均 成 绩 进 行 格式 化 , 如 果 用 户 想 对 成 绩 进行 格式 化 , 可 以 使 用 函数 number format0 实 现 ， 
其 格式 为 : 


string number_format ( float number [, int decimals]) 
参数 说 明 : 

number: 表示 要 进行 格式 化 输出 的 数字 。 
decimals; 表示 要 保留 的 位 数 。 


实例 405 趣味 指数 : 克 克 雪 克 | 
图 实例 说 明 


在 销售 管理 系统 中 ， 商 家 会 根据 不 同 商品 的 销售 利润 来 确定 该 商品 的 进货 数量 。 运 行 本 实例 ， 如 图 8.75 所 
示 ， 单 击 图 中 的 “获取 利润 最 小 的 商品 信息 ”按钮 ， 即 可 将 销售 利润 最 小 的 商品 信息 显示 在 图 中 最 后 一 行 


8.75 ”利润 最 小 的 商品 输出 


力 关键 技术 


SQL 语言 中 ， 获 取 某 字段 的 最 小 值 可 以 通过 函数 min0 实 现 ， 该 函数 的 使 用 方法 如 下 : 
min([all | distinet] expression) 


图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 获 取 利润 最 小 的 商品 信息 ” 
人 8.75 所 示 的 内 容 ， 核 心 代码 如 下 : 

< 


Sconn = mysql_connect("localhost","root","111") or die ("connect mysql false"): /连接 MySQL 


mysql_select_db("db_database08",Sconn) or die ("connect database false"); // 连 接 MySQL 数据 库 
mysql_query("set names utf8"): // 设 置 编码 格式 

Srss = mysql_query("select * from tb_demo061"); /返回 结果 集 

?> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 商 品名 称 </td><td background="pic/head.JPG"> 
进货 价格 /元 </td><td background="pic/head.JPG"> 销 售 价格 /元 </td><td background="pic/head.JPG"> 进 货 数 量 / 件 </td><td 
background="pic/head.JPG"> 进 货 日 期 </td></tr> 

<?php 


?> 


while($rst = mysql_fetch_row($rss){ 1/ 循环 输出 结果 


<tr><td background="pic/head. JPG"><?php echo S$rst[0]:?></td><td background="pic/head JPG"><?php echo Srst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic /head JPG"><?php echo $rst[3]:?></td><td 
background="pic/head JPG"><?php echo $rst[4]:?></td><td background="pic /head.JPG"><?php echo $rst[5]:?></td></tr> 


第 8 章 MySQL 数据 库 与 PHP 
<php 


六 
if($_GET[page] — "1"){ // 当 page 等 于 1 时 
$sql = "select min(outshop-inshop).name from tb_demo061 "; JWSQL 语句 
Srs = mysql_query($sql); // 返 回 结 果 集 
Srst = mysql_fetch_row($rs); /输出 结果 


?> 

<tr><td background="pic/head.JPG"> 利 润 最 小 的 商品 </td><td background="pic/head.JPG"><?php echo S$rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"></td><td background="pic/head.JPG"></td><td 
background="pic/head.JPG"></td></tr></table></td></tr></table></td></tr></table> 

<?php 
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心 法 领悟 405: 聚合 函数 min0 的 主要 应 用 。 
聚集 函数 min0 被 广泛 应 用 于 电子 商务 系统 中 ,主要 用 于 商家 在 进货 之 前 计算 自己 商品 的 保底 利润 ， 也 就 是 
最 小 利润 ， 以 防止 因 市 场 价格 变动 而 造成 损失 。 


实例 406 趣味 指 就: 广 廊 太 


je - 


图 实例 说 明 


在 商品 销售 管理 系统 中 ， 商 品 的 销售 利润 统计 模块 是 必 不 可 少 的 。 运 行 本 实例 ， 如 图 8.76 所 示 ， 在 图 中 文 
本 框 中 输入 某 月 份 ， 单 击 “查询 ”按钮 ， 即 可 将 2005 年 销售 额 最 大 的 商品 信息 显示 出 来 。 


使 用 聚集 团 数 而 ax() 求 利润 曲 高 的 商品 


Mem 

[7 5350 祥云 宝 人 广 林 

1 二 记 了 。。。 320402 。。 祥 二 主人 上 

366 PIMB 215455 东 廊 广场 H 面 
367 。 19 本 妊 。。 3000 东方 广场 和 
JP。 320403 。。 祥 二 宝生 4 到 


8.76 ”获取 月 利润 最 大 的 商品 信息 


力 关键 技术 


实现 本 实例 ， 主 要 应 用 到 SQL 语言 中 的 max0 函 数 ， 该 函数 的 语法 格式 如 下 : 

max([all | distinct] expression) 

参数 说 明 ， 

all: 表示 对 指定 字段 的 所 有 值 进行 聚集 函数 运算 ，all 为 默认 值 ， 如 果 不 加 参数 all 或 distinct， 则 表示 对 指 
定 字段 的 所 有 记录 进行 聚集 运算 。 

distinet。 表 示 对 指定 字段 的 所 有 非 重复 记录 求 最 大 值 。 

expression: 是 精确 数字 或 近似 数字 数据 类 型 (bit 数据 类 型 除外 ) 分 类 的 表达 式 。 


图 设计 过 程 
(1) 建立 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 
11"); // 连 接 MySQL 数据 库 


PHP 开发 实例 大 全 (基础 卷 ) 


mysql_select_db("db_database08".Sconn): 
mysql_query("set names gb2312"); 
> 


(2) 显示 商品 表 中 所 有 商品 的 销售 信息 ， 代 码 如 下 : 
<?php 


// 连 接 数 据 库 
// 设 置 编码 格式 


include_once("conn php"); // 包 含 数据 库 连接 文件 
$sql=mysql_query("select * from tb_demo062".Sconn): // 执 行 查询 操作 
$info=mysql_fetch_array($sq]): /返回 结果 集 
if(Sinfo—false) { // 判 断 结 果 集 是 否 存 在 
echo " 暂 无 商品 信息 !"; 
jelsef 
dof 
?> 
<t> 
<td height="25" bgeolor="#FFFFFF"><div align="center"><?php echo $info[id]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[name]:?></div></td> 
<td height="25" bgeolor="#FFFFFF"><div align="center"><?php echo $info[sale]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[shopname]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfofxdate]:?></div></td> 
<td height="25" bgeolor="#FFFFFF"><div align="center"><?php echo $info[sellman]:?></div></td> 
<ltr> 
<?php 
jwhile(Sinfo=mysql_fetch_array($sqD); /循环 输出 结果 
> 
(3) 显示 月 销售 额 最 大 的 商品 信息 ， 代 码 如 下 : 
<?php 
if($_POST[submit]!="") { // 通 过 POST 方式 传递 参数 
$yue=$_POST[yue]: // 将 参数 值 赋 给 变量 


$sql=mysql_query("sclect * from tb_demo062 where sale in (sclect max(sale) from tb_demo062 where month(xdate)=$yue and 


year(xdate)=2005)",$conn); 
Sinfo=mysql_fetch_array($sql); 
if($info—false) { 
echo "不 存在 该 月 I"; 
Jelse{ 


<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php 


1/ 执行 查询 操作 
// 返 回 结果 集 
// 如 果 结果 集 不 存在 


echo Sinfo[id]:?></div></td> 

echo Sinfo[name]:?></div></td> 
echo Sinfo[sale]:?></div></td> 

echo Sinfo[shopname]:?></div></td> 
echo Sinfo[xdate]:?></div></td> 
echo Sinfo[seliman]:?></div></td> 


mysql_close($conn); 


国 秘笈 心 法 
心 法 领悟 406: 封装 一 个 数据 库 连接 类 。 


本 实例 利用 包含 MySQL 数据 库 连 接 文 件 实现 连接 数据 库 。 用 户 可 以 自行 将 数据 库 连接 文件 写成 一 个 类 ， 
将 查询 等 操作 都 封装 到 类 中 。 


1/ 关闭 数 据 库 连 接 


实例 407 


力 实例 说 明 
在 PHP 项 目 开发 过 程 中 ，SQL 语言 的 count0 函 数 得 到 了 广泛 的 应 用 ,例如 在 实现 记录 的 分 页 显示 时 ， 需 要 


550 


第 8 章 MySQL 数据 库 与 PHP 


通过 count0 函 数 求 出 表 中 所 有 记录 的 总 和 。 本 实例 将 讲解 SQL 语言 中 count0 函 数 的 应 用 。 运行 本 实例 ， 如 图 8.77 
所 示 ， 首 先 在 图 中 的 文本 框 中 输入 某 数 值 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 所 有 利润 大 于 该 数值 的 数据 求 出 。 


8.77 取得 大 于 某 值 的 数据 


图 关键 技术 


统计 表 中 满足 一 定 条 件 的 记录 个 数 ， 可 以 通过 SQL 语言 的 countO 函 数 实现 ， 该 函数 的 详细 说 明 请 详 见 实例 
396， 这 里 不 再 袭 述 。 

本 实例 实现 取得 大 于 某 值 的 数据 的 SQL 语句 如 下 : 

select count(*) as a from tb_demo061 where $_ POST[text] < outshop; 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 在 文本 框 中 输入 内 容 时 ， 单 击 “ 查 


询 ” 按 钮 ， 显 示 如 图 8.77 所 示 的 内 容 ， 核 心 代码 如 下 : 
<2php 


if($_POST[sub) { // 单 击 按钮 
if$_POST[text] !="" || $_POST[text] != "输入 查询 值 "){ 1/ 判断 文本 框 信息 
if(preg_mateh("/\d/".$_POST[textD){ // 正 则 表达 式 验 证 信息 
Srs = mysql_query("select count(*) as a from tb_demo061 where $_POST[text] < outshop"); 。“ // 返 回 结果 集 
Srst = mysql fetch_row($rs): /输出 结果 
> 
<table><tr><td width="580px" align="center"> 共 查找 到 <?php echo $rst[0]:?> 条 </td></tr></table> 
< 
9 jelse{ 
echo "<script>alert(' 请 正确 输入 );</script>"; JIavaScript 提示 
jelsef 
echo "<script>alert( 请 在 文本 框 中 输入 内 容 );</script>"; //JavaScript 提示 
} 
?> 
图 秘笈 心 法 


心 法 领悟 407: 分 析 count0 聚 集 函 数 与 mysql num rows0 函 数 。 
count() 聚 集 函 数 与 PHP 操作 MySQL 函数 mysql_ num _rows0 在 处 理 分 页 显示 时 作用 完全 相同 ， 但 是 后 者 功 
能 较 单一 ， 不 够 灵活 。 


| 
高 级 
| 


实例 408 Ue 伍 食 太太 


力 实例 说 明 


SQL 语言 中 ， 获 取 表 中 的 第 一 条 记录 或 最 后 一 条 记录 可 以 通过 函数 first0 和 last0 实 现 ， 由 于 Access 数据 库 


[ERI 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


对 这 两 个 函数 的 支持 较为 完善 ， 本 实例 将 采用 Access 作为 后 台数 据 库 。 运 行 本 实例 ,如 图 8.78 所 示 ， 分 别 单 击 
图 中 的 “获取 第 一 条 记录 ”和 “获取 最 后 一 条 记录 ”按钮 即 可 获得 表 中 的 第 一 条 或 最 后 一 条 记录 。 


人 二 ES 5 | Ea 
0312106 | EE 已 三 | | 至 


图 8.78 ”聚集 函数 first0 和 last0 的 使 用 


图 关键 技术 


SQL 语言 中 ， 获 取 表 中 的 第 一 条 记录 或 最 后 一 条 记录 可 以 通过 函数 first0 和 last0 实 现 ， 这 两 个 函数 的 使 用 
语法 如 下 : 

first(expression) 

last(expression) 


expression 代表 一 个 字符 串 表达 式 ， 它 包含 要 使 用 的 数据 字段 ， 或 者 是 使 用 该 数据 字段 参与 执行 的 表达 式 ， 
expression 中 的 操作 可 以 包含 表 的 字段 、 常 量 等 。 


力 设计 过 程 
(1) 建立 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 


<?php 
a com("adodb.connection"): 1/ 实例 化 adodb.connection 
Sconnstr="provider=microsoftjet.oledb.4.0;data source=".realpath("./data/db_database07_186.mdb"): 1/ 调 用 db_database07_196. 
ee 
(2) 判断 用 户 提交 的 名 称 ， 从 而 确定 显示 第 一 条 记录 还 是 最 后 一 条 记录 ， 代 码 如 下 : 
<?php 
function convert($text){ // 自 定义 转 码 函数 


return iconv('gbk', "utf-8', $text); 


本 POST[submit1]!="" || $_POST[submit2]!="") { 
include("conn.php"); // 包 含 连接 数据 库 文件 
Srs=new com("adodb.recordset"); 1/ 实例 化 对 象 
if($_POST[submit1]!="") 


{ 
S$rs->open("select first(sno) as snol ,first(sname) as snamel. first(sclass) as sclassl first(ssubiect) as ssubiject] first(sscore) as sscorel from 
score",$conn,3,1); 


yelscif($_POST[submit2]!="){ 


S$rs->open("select last(sno) as snol last(sname) as sname]l. last(sclass) as sclassl.last(ssubject) as ssubject1 ,last(sscore) as sscorel from 
score",Sconn,3,1); 


} 

if($rs->eof]| $rs->boD){ 

> 
<tr> 

<td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 没 有 查找 到 该 学 生成 绩 ! </div></td> 

<ltr> 
<?php 

} elsef 


Ws 
<zphp 
while(!$rs->eof){ 
> 
<t> 
<td width="170" height="20" bgcolor="#FFFFFF"><div align="center"> 
<?php echo convert($rs->fields("sno1")->value)?> 
</div></td> 
<td width="170" bgcolor="#FFFFFF"><div align="center"> 
<?php echo convert($rs->fields("sname1")->value)?> 
</div></td> 
<td width="143" bgcolor="#FFFFFF"><div align="center"> 
<?php echo convert($rs->fields("sclass1")->value)?> 
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</div></td> 
<td width="130" bgcolor="#FFFFFF"><div align="center"> 
<?php echo convert($rs->fields("ssubject1")->value)?> 
<Jdiv><htd> 
<td width="131" bgcolor="#FFFFFF"><div align="center"> 
<?php echo convert($rs->fields("sscore1")->value)?> 
<ldiv><hd> 
< 
< 
Srs->movenext; 
} 
} 
?> 


心 法 领悟 408: Access 数据 库 一 一 PHP 程序 员 必修 课程 之 一 。 

Access 数据 库 并 不 是 与 PHP 操作 数据 库 联合 使 用 的 首选 ， 但 是 由 于 各 个 数据 库 之 间 存 在 差异 ， 函 数 支持 程 
度 也 有 强 有 弱 ， 所 以 作为 一 个 优秀 的 PHP 程序 员 ， 不 仅 要 掌握 MySQL 这 一 种 数据 库 ， 还 要 对 Access 数据 库 有 
所 了 解 。 


87 多 表 查 询 


在 实际 的 Web 开发 过 程 中 ， 经 常 将 类 别 不 同 的 信息 存储 在 不 同 的 表 中 ， 表 之 间 通 过 特定 的 字段 相互 关联 ， 
所 以 在 任何 一 个 有 规模 的 Web 项 目 中 ， 都 可 以 看 到 多 表 查 询 的 身影 。 本 节 将 通过 几 个 典型 的 实例 讲解 SQL 语 
言 中 多 表 查 询 的 使 用 方法 。 


r 一 Ra 
力 实例 说 明 


在 实际 项 目 开发 过 程 中 ， 经 常 需要 将 不 同 的 信息 存储 在 不 同 的 表 中 ， 表 与 表 之 间 通 过 某 字段 相互 关联 ， 从 
而 使 表 的 指针 形成 一 种 连 动 关系 进而 可 以 通过 SQL 语言 的 SELECT 语句 实现 多 表 查 询 。 运 行 本 实例 , 如 图 8.79 
所 示 ， 在 图 中 文本 框 中 输入 要 查询 成 绩 的 学 生 学 号 ， 单 击 “ 查 找 ” 按 钮 ， 即 可 将 学 生 信息 和 该 学 生 的 各 科 成 绩 
查找 出 来 。 


pe 
-外 ss ,5 


党 生 10 学 上 址 吉 于 住址 入 学 上 期 。 数学 才 法 分 就 英 话 壮大 分数“ 话 文才 分 
1 电击 打 攻 表 01i-ir-11 51 0 9 


图 8.79 多 表 查 询 


图 关键 技术 


SQL 语言 中 ， 通 过 where 子 句 实现 多 表 查 询 ， 所 要 查找 的 字段 名 最 好 用 “表明 .字段 名 ”表示 ， 这 样 可 以 防 
止 因 表 之 间 字 自重 名 而 造成 无 法 获知 该 字段 属于 哪个 表 。 在 where 子 句 中 ， 多 个 表 之 间 所 形成 的 连 动 关 系 应 按 


如 下 形式 书写 : 
表 1 字段 = 表 2 字段 and 其 他 查询 条 件 
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综 上 所 述 ， 实 现 多 表 查 询 应 按 如 下 形式 : 
sclect 字段 名 from 表 1. 表 2..where 表 1 字段- 表 2 字段 and 其 他 查询 条 件 


图 设计 过 程 
编写 index.php 文件 ， 当 用 户 在 文本 框 中 输入 数据 并 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.79 所 示 的 内 容 ， 核 
心 代码 如 下 : 
<?php 
$conn = mysql_connect("localhost", "root","111") or die ("Connect MySQL false"); /| 连接 MySQL 
mysql_select_db("db_database08",$conn); // 连 接 数据 库 
mysql_query("SET NAMES UTF8"): // 设 置 编码 格式 
if($_POST[sub){ // 当 单 击 按钮 时 
Srs = mysql_query("select a.id.a.name.a.address.a.date.b.math,b.english.b.chinese from tb_demo065 tcl as b.tb_demo065 as a where aid=bjid 
and a.id='$_POST[text]"); // 返 回 结果 集 
?> 


<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓名 </td><td 
background="pic/head.JPG"> 家 庭 住址 </td><td background="pic/head.JPG"> 入 学 日 期 </td><td background="pic/head.JPG"> 数 学 考试 分 数 </td><td 
background="pic/head.JPG"> 英 语 考试 分 数 </td><td background="pic/head.JPG"> 语 文 考试 分 数 </td></tr> 
<?php 

while($rst = mysql_fetch_row($rs)){ /循环 输出 结果 


<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo S$rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic /head.JPG"><?php echo $rst[3]:2></td><td 
background="pic/head.JPG"><?php echo S$rst[4]:?></td><td background="pic/head.JPG"><?php echo S$rst[5]:?></td><td 
background="pic/head.JPG"><?php echo S$rst[6]:?></td></tr> 
<?php 

} 
} 
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心 法 领悟 409: 设置 两 表 关 联 的 注意 事项 。 
本 实例 在 where 子 句 上 ， 以 两 张 表 的 id 字段 信息 相同 作为 条 件 建立 两 表 关联 ， 笔 者 意 在 显示 实例 原理 ， 在 
实际 开发 中 不 建议 这 样 使 用 ， 最 好 使 用 主 外 键 约束 来 实现 。 


高 级 
实例 410 起 味 效 ， 裕 宙 宙 
国 实例 说 明 


为 了 提高 SQL 语句 的 可 读 性 , 经 常 采取 为 表 取 别名 的 方式 对 表 进 行 查询 。 运 行 本 实例 ， 如 图 8.80 所 示 ， 首先 
在 图 中 的 文本 框 中 输入 要 查询 的 学 生成 绩 的 学 号 ， 然 后 单 击 “查询 ”按钮 ， 即 可 将 该 学 生 的 学 生成 绩 查找 出 来 。 


8.80 ”使 用 表 的 别名 


图 关键 技术 


SQL 语言 中 ， 可 以 通过 两 种 方式 为 表 指 定 别名 ， 第 一 种 是 通过 关键 字 as 指定 ， 例 如 : 
sclect 字段 名 fom 表 名 as 表 的 别名 where 条 件 .… 
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第 二 i es bath 例如 : 
select 字段 名 fom 表 名 表 的 别名 where 条 


相关 例 将 利用 家 的 别名 实现 多 理光 代码 如 下 : 


sclect a.id.a.name,a.address.a.date.b.math.b.english.b.chinese from tb_demo065 tcl as b .tb_demo065 as a where a.id=b.id and aid-$_POST[text]': 


力 设计 过 程 


创建 网 页 文件 index.php。 编 写 网 页 框架 ， 开启 MySQL 服务 并 连接 MySQL 数据 库 。 当 在 文本 框 中 输入 信 


息 ， 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.80 所 示 的 内 容 ， 核 心 代码 如 下 : 
<?php 
Sconn = mysql_connect("localhost","root","111") or die ("Connect MySQL false"); // 连 接 MySQL 
mysql_select_db("db_database08",$conn):; /连接 MySQL 数据 库 
mysql_query("SET NAMES UTFS"): // 设 置 编码 格式 
if($_POST[sub){ /| 单 击 按钮 


Srs = mysql_query("select a.id,a.name,a.address.a.date.b.math,b.english.b.chinese from tb_demo065 tel as b ,tb_demo065 as a where a.id=b.id 
and a.id='$_POST[text]"); // 返 回 结果 集 


> 


<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓名 </td><td 
background="pic/head.JPG"> 家 庭 住址 </td><td background="pic/head.JPG"> 入 学 日 期 </td><td background="pic/head.JPG"> 数 学 考试 分 数 </td><td 
background="pic/head.JPG"> 英 语 考试 分 数 </td><td background="pic/head.JPG"> 语 文 考试 分 数 </td></tr> 


<?php 


while(Srst= 


Se 


mysql_fetch_row($rs){ 1/ 循环 输出 结果 


<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head. JPG"><?php echo $rst[1]:?></td><td 
background="pic/head. JPG"><?php echo Srst[2]:?></td><td background="pic/head.JPG"><?php echo S$rst[3]:?></td><td 
background="pic/head.JPG"><?php echo S$rst[4]:?></td><td background="pic /head.JPG"><?php echo Srst[5];?></td><td 
background="pic/head JPG"><?php echo Srst[6]:?></td></tr> 


<?php 
} 

} 

> 


图 秘笈 心 法 


心 法 领悟 410: 使 用 表 的 别名 的 注意 事项 。 
(1) 别名 通常 是 一 个 缩短 了 的 表 名 ， 用 于 在 连接 中 引用 表 中 的 特定 列 ， 如 果 连 接 的 多 个 表 中 有 相同 的 名 称 
列 存在 ， 必 须 使 用 表 名 或 表 的 别名 限定 列 名 。 


(2) 如 果 定 
实例 411 


力 实例 说 明 


SQL 语言 中 ， 


义 了 表 的 别名 就 不 能 再 使 用 表 名 。 
高 级 | 


趣味 指数 : 三 食 信 三 | 


使 用 关键 字 union 可 以 将 多 张 表 的 信息 合并 输出 。 如 图 8.81 所 示 为 数据 库 中 无 关联 的 两 张 表 ， 


运行 本 实例 ， 单 击 


二 “合并 ”按钮 ， 即 可 将 这 两 张 表 的 信息 合并 输出 ， 如 图 8.82 所 示 。 


id ame price name pwd 
Prox 1 an 15100 0P2 FF FX 1 1 
FX 2 m0 200024 三 X21 105 
a 熟 会 自动 A 机 3500 30100724 厂 3d 105 
FX to 200024 FF FX 4 107 
图 8.81 两 张 无 关 联 表 图 8.82 合并 多 个 结果 集 


PHP 开发 实例 大 全 (基础 卷 ) 


图 关键 技术 


SQL 语言 中 ， 可 以 通过 关键 字 union 或 all 将 多 个 select 语句 的 查询 结果 合并 输出 ， 这 两 个 关键 字 的 使 用 说 
明 如 下 : 

union: 利用 该 关键 字 可 以 将 多 个 select 语句 的 查询 结果 合并 输出 ， 并 删除 重复 行 。 

all;， 利用 该 关键 字 可 以 将 多 个 select 语句 的 查询 结果 合并 输出 ， 但 不 删除 重复 行 。 

在 使 用 union 或 all 关键 字 将 多 张 表 合并 输出 时 ， 查 询 结果 必须 具有 相同 的 结构 并 且 数据 类 型 必须 兼容 。 


图 设计 过 程 
创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 合 并 ”按钮 时 ， 显 示 如 图 8.82 
所 示 的 内 容 ， 代 码 如 下 : 


Se =mysql_conneet("localhost", "root","111") or die ("Connect MySQL false"); /连接 MySQL 
mysql_select_db("db_database08",Sconn); // 连 接 数 据 库 
mysql_query("SET NAMES UTFS8"); /设置 编码 集 
if($_GET[id] =— "1"){ // 当 记 等 于 1 时 


// 返 回 结果 集 
Srs = mysql_query("select uid,name.price from tb_demo067_tcl union select id.name.pwd from tb_demo067") or die ("false"); 


> 
<table width="580px"><tr><td background="pic /head.JPG">ID</td><td background="pic/head.JPG"> 名 称 </td><td background="pic/head.JPG"> 说 明 
<ltd></t> 
<php 

while($rst = mysql_fetch_array($rs)){ 1/ 循环 输出 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:2></td><td 
background="pic/head.JPG"><?php ccho $rst[2]:?></td></tr> 
<?php 

} 
} 
?> 


心 法 领悟 411: 使 用 union 关键 字 的 注意 事项 。 
在 使 用 union 关键 字 时 两 张 表 的 字段 数量 必须 相同 ， 否 则 会 提示 SQL 语句 有 错误 。 


实例 412 趣味 指数 : 请 究 庚 穴 | 


国 实例 说 明 
在 数据 库 系统 开发 过 程 中 ， 殴 套 查询 得 到 了 广泛 的 应 用 ， 本 实例 将 通过 霸 套 查询 实现 按 指定 的 学 生 学 号 查 


询 学 生 的 成 绩 信息 。 运行 本 实例 , 如 图 8.83 所 示 , 首先 在 图 中 的 文本 框 中 输入 要 查询 的 学 生 学 号 , 然后 单 击 “ 查 
找 ” 按 钮 ， 即 可 将 该 学 号 所 对 应 的 学 生 信息 查找 出 来 。 


0 由 杨 男 EE] 


图 8.83 嵌 套 查询 


第 8 章 MySQL 数据 库 与 PHP 


图 关键 技术 


本 实例 是 通过 一 个 嵌 套 子 查 询 实现 的 。 子 查询 是 一 个 select 查询 , 返回 单个 值 且 嵌 套 在 select、 insert、 update 
和 delete 语句 或 其 他 查询 语句 中 。 任 何 可 以 使 用 表达 式 的 地 方 都 可 以 使 用 子 查询 。 

子 查询 也 称 内 部 查询 或 内 部 连接 ， 包 含 子 查询 的 语句 称 为 外 部 查询 或 外 部 选择 。 本 实例 中 实现 嵌 套 查询 的 
代码 如 下 : 

select id,name,sex.date from tb_demo068 where id in(select id from tb_demo068 where id=$ POST[text]): 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 在 文本 框 中 输入 学 生 ID， 单 击 “ 查 询 ” 
按钮 ， 显 示 如 图 8.83 所 示 的 内 容 。 核 心 代码 如 下 : 


区 =mysql_connect("localhost","root","111") or die ("Connect MySQL false"); // 连 接 MySQL 
mysql_select_db("db_database08",$conn): // 连 接 MySQL 数据 库 
mysql_query("SET NAMES UTF8"); // 设 置 编码 格式 
ifS$_POST[sub]){ // 单 击 按钮 

/返回 结果 集 


Sirs = mysqL_query("sclectidname sexsdate from tb_demo068 where id in(select id from tb_demo068 where id=$_POST[text])") or die ("false"); 


> 
<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓名 </td><td 
background="pic/head.JPG"> 学 生性 别 </td><td background="pic/head.JPG"> 入 学 时 间 </td></tr> 
<php 
while($rst = mysql_fetch_array($rs)){ 1/ 循环 输出 结果 
> 
<tr><td background="pic/head.JPG"><?php echo S$rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/head.JPG"><?php echo S$rst[3]:?></td></tr> 
<2php 
} 
} 
> 


国 秘笈 心 ; 


心 法 领悟 412: 浅 谈 内 连接 。 
本 实例 运用 的 媒 套 查询 的 原理 是 把 查询 结果 作为 where 子 句 的 查询 条 件 ， 也 就 是 所 谓 的 内 连接 。 


a . 级 
图 实例 说 明 


在 实际 的 数据 库 系 统 开发 过 程 中 ， 经 常用 到 多 表 的 嵌 套 查询 。 本 实例 对 存在 一 定 关联 的 两 张 表 实 现 较为 复 
杂 的 嵌 套 查询 。 运 行 本 实例 ， 效 果 如 图 8.84 所 示 。 


8.84 ”复杂 的 嵌 套 查询 


PHP 开发 实例 大 全 (基础 卷 ) 


图 关键 技术 
多 表 之 间 的 顽 套 查询 可 以 通过 谓词 in 实现 ， 该 谓词 的 语法 格式 如 下 : 


test_expression[not] in{ 
subquery 


} 

参数 说 明 : 

test_expression: 指 SQL 表达 式 。 

subquery: 包含 某 列 结果 集 的 子 查询 ， 该 列 必须 与 test_expression 具有 相同 的 数据 类 型 。 
力 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 查 询 ”按钮 时 ， 显示 如 图 8.84 
所 示 的 容 ， 代 码 如 下 : 

<?pl 


$conn = mysql_connect("localhost", "root","111") or die ("Connect MySQL False"); /| 连接 MySQL 
mysql_select_db("db_database08",$conn) or die ("Connect Database False"): /连接 MySQL 数据 库 
mysql_query("SET NAMES UTFS8"): /设置 编码 格式 
这 $_POST[sub]){ // 单 击 按钮 
$sql = "select * from tb_demo069_people where uid in (select deptID from tb_demo069_dept where deptName ='$_POST[text])"; //SQL 语句 
S$rs = mysql_query($sql); 1/ 返回 结果 集 


> 
<table width="580px"><tr><td background="pic/head JPG"> 员 工 编号 </td><td background="pic/head.JPG'"> 部 门 编号 </td><td 
background="pic/headJPG'"> 员 工 姓名 </td><td background="pic/head.JPG"> 性 别 </td></tr> 
<?php 
while(Srst= mysql feteh_row($rs){ /循环 输出 
?> 


<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic /head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/head.JPG"><?php echo $rst[3]:?></td></tr> 
<?php 

} 
} 


2> 


国 秘笈 心 法 
心 法 领悟 413: 多 表 菊 套 查询 的 原理 。 


对 于 数据 表 的 嵌 套 查询 ， 用 户 一 定 要 掌握 其 查询 原理 ， 即 无 论 是 多 少 张 表 进行 嵌 套 ， 表 与 表 之 间 一 定 存在 
某 种 关联 ， 通 过 where 子 句 建立 此 种 关联 实现 查询 。 


高 级 | 
实例 414 趣味 指数 : 傅 塘 庚 庚 | 
力 实例 说 明 


嵌 套 查询 在 实际 项 目 开 发 过 程 中 应 用 较 频繁 ， 可 以 通过 一 条 SQL 语句 实现 多 表 之 间 的 复杂 查询 。 本 实例 将 
利用 嵌 套 查询 实现 查询 部 门 员工 与 公司 部 门 的 详细 信息 。 运 行 本 实例 ， 效 果 如 图 8.85 所 示 。 


图 8.85 查询 统计 应 用 


第 8 章 MySQL 数据 库 与 PHP 


图 关键 技术 


本 实例 中 的 嵌 套 查询 同样 是 通过 谓词 n 实现 的 。 谓 词 in 可 以 检测 结果 集中 是 否 存在 某 个 特定 的 值 ， 如 果 检 
测 成 功 就 执行 外 部 的 查询 。 

本 实例 实现 查询 统计 的 SQL 语句 如 下 : 

sclect * from tb_demo069 _ people where uid in (sclect deptID from tb_demo069 dept where deptName ='$_POST[select]'; 
图 设计 过 程 


创建 脚本 文件 index.php， 编写 下 拉 列 表 框 。 选择 部 门 ， 当 单 击 “ 查 询 ”按钮 时 ， 显示 如 图 8.85 所 示 的 内 容 ， 


代码 如 下 : 
<?php 
Sconn = mysql_connect("localhost","root","111") or die ("Connect MySQL False"); // 连 接 MySQL 
mysql_select_db("db_database08",$conn) or die ("Connect Database False"); /连接 MySQL 数据 库 
mysql_query("SET NAMES UTFS8"): /设置 编码 格式 
if($_POST[sub){ / 单 击 按钮 
if($_POST[select] — "1"){ /下 拉 列 表 框 设置 
echo "<script>alert( 请 选择 部 门 );</script>"; //JavaScript 设置 
else 
2 //SQL 语句 
$sql = "select * from tb_demo069_people where uid in (select deptID from tb_demo069_dept where deptName ='$_POST[select])"; 
Srs = mysql_query($sql); 1/ 返回 结果 集 


?> 
<table width="580px"><tr><td background="pic/head.JPG"> 员 工 编号 </td><td background="pic/head.JPG"> 部 门 名 称 </td><td 
background="pic/head.JPG"> 员 工 姓名 </td><td background="pic/head.JPG"> 性 别 </td></tr> 
Iphp 
while(Srst = mysql fetch_row($rs){ 1/ 循环 输出 结果 
> 
<tr><td background="pic/head.JPG"><?php ccho S$rst[0]:?></td><td background="pic/head.JPG"><?php echo $_ POST[select]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic /head.JPG"><?php echo Srst[3]:?></td></tr> 
<?php 
} 


} 
} 
> 


国 秘笈 心 法 

实现 多 表 的 嵌 套 查询 时 ， 还 可 以 同时 使 用 谓词 any、some 和 all， 这 些 谓 词 被 称 为 定量 比较 谓词 ， 可 以 和 比较 
运算 符 联 合 使 用 ， 判 断 是 否 全 部 返回 值 都 满足 搜索 条 件 。some 和 any 谓词 是 存在 量 的， 只 注重 是 否 有 返回 值 满足 
搜索 要 求 ， 这 两 个 谓词 的 含义 相同 ， 可 以 蔡 换 使 用 ，all 谓词 称 为 通用 谓词 ， 它 只 关心 是 否 有 谓词 满足 搜索 要 求 。 

any | some |all 谓词 的 语法 形式 如 下 : 

scalar_expression {查询 条 件 运算 符 }{ some | any }(subquery) 

参数 说 明 : 

scalar_expression: 指 任何 有 效 的 SQL 表达 式 。 

subquery: 指 包含 某 列 结果 集 的 子 查询 。 


0 | 


力 实例 说 明 
在 实际 项 目 开发 过 程 中 经 常用 到 从 一 个 信息 较为 完善 的 表 中 派生 出 一 个 只 含有 几 个 关键 字段 的 信息 表 。 本 


S59 


PHP 开发 实例 大 全 (基础 卷 ) 


实例 将 从 学 生成 绩 信息 表 中 派生 出 另 一 个 只 含有 学 号 和 成 绩 的 表 。 运 行 本 实例 ， 如 图 8.86 所 示 为 学 生成 绩 信息 
表 的 全 部 内 容 ， 单 击 图 8.87 中 的 “查询 学 生成 绩 ” 按 钮 ， 即 可 将 所 有 学 生 的 姓名 和 成 绩 显示 出 来 。 


刘 mame sex age chinese math english 
FAX14M 昂 了 4 gm % 
Pl Be | 到 红 果 二 j 芍 双双 Ed 
PN XI 相生 昂 27 8 电 Eg 
图 8.86 ”学 生成 绩 信息 表 图 8.87 使 用 子 查 询 作 派生 的 表 
图 关键 技术 


子 查询 是 一 个 用 于 处 理 多 表 操 作 的 方法 ， 子 查询 的 语法 格式 如 下 : 
select [all | distinet] <select item list> 
from <table list> 
[where <search condition>] 
[group by <group item list>] 
[having <group by search condition>] 


本 实例 实现 使 用 子 查询 作 派 生 的 表 的 SQL 语句 如 下 : 


select people.name,people.chinese,people.math,people.english from (select name,chinese.math,english from tb_demo071) as people; 
图 设计 过 程 

创建 脚本 文件 index.php。 编 写 网 页 框架 ， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 查 询 学 生成 
绩 ” 按 钮 时 ， 显 示 如 图 8.87 所 示 的 内 容 ， 核 心 代码 如 下 : 

<?php 


$conn = mysql_connect("localhost", "root","111") or die ("Connect MySQL False"); // 连 接 MySQL 
mysql_select_db("db_database08",Sconn); /连接 MySQL 数据 库 
mysql_query("SET NAMES UTF8"): // 设 置 编码 集 
if($_GET[id] = "1"){ // 如 果 地 址 栏 参数 i 等 于 1 

S$rs = mysql._query("select people.name.people.chinese.people.math.people.english from (select name.chinese,math,english from tb_demo071) as 
people"); // 返 回 结果 集 


> 
<table width="580px"><tr><td background="pic/head.JPG"> 学 生 姓 名 </td><td background="pic/head.JPG"> 语 文成 绩 </td><td 
background="pic/head.JPG"> 数 学 成 绩 </td><td background="pic/head.JPG"> 英 语 成 绩 </td></tr> 

<2php 


while($rst = mysql fetch_row($rs)){ /循环 输出 结果 
2> 
<tr><td background="pic/head.JPG"><?php echo S$rst[0]:?></td><td background="pic/head.JPG"><?php echo $rst[1]:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/head.JPG"><?php echo S$rst[3]:2></td></tr> 
?php 


} 


0 
7 


国 秘笈 心 法 


心 法 领悟 415: 使 用 子 查询 的 注意 事项 。 
SQL 语言 中 ， 应 用 子 查询 应 遵循 以 下 规则 : 
(1) 由 比较 运算 符 引 入 的 内 层 子 查询 只 包含 一 个 表达 式 或 列 名 ,在 外 层 语句 中 的 where 子 句 内 命名 的 列 必 
须 与 内 层 子 查询 命名 的 列 兼容 。 
(2) 由 不 可 更 改 的 比较 运算 符 引 入 的 子 查询 (比较 运算 符 后 面 不 跟 关 键 字 any 或 al) 不 包括 group by 或 
having 子 句 ， 除 非 预先 确定 了 成 组 或 单个 的 值 。 
(3) 用 exists 引入 的 select 列表 一 般 都 由 * 组 成 ， 不 必 指 定 列 名 。 


第 8 章 MySQL 数据 库 与 PHP 
(4) 子 查 询 不 能 在 内 部 处 理 其 结果 。 


实例 416 


力 实例 说 明 


本 实例 通过 计算 各 科 平 均 成 绩 作为 子 查询 表达 式 的 方式 来 取得 学 生 的 各 科 平 均 成 绩 。 运 行 本 实例 , 如 图 8.88 
所 示 ， 单 击 图 中 的 “显示 平均 成 绩 ” 按 钮 ， 即 可 将 该 班级 学 生 的 所 有 学 科 的 平均 成 绩 显 示 在 图 中 最 后 一 行 


图 8.88 ”使 用 子 查询 作 表 达 式 


图 关键 技术 
本 实例 中 ， 求 得 学 生 各 科 平均 成 绩 的 代码 如 下 : 


select (select avg(chinese) from tb_demo071).,(select avg(math) from tb_demo071),(select avg(english) from tb_demo071) from tb_demo071; 
其 中 ，select avg(chinese) from tb_demo071、select avg(math) from tb_demo071 和 select avg(english) from 
tb_demo071 为 该 SQL 语句 的 子 查询 ， 分 别 用 于 获得 该 班级 学 生 的 语文 、 数 学 和 英语 的 平均 成 绩 。 


图 设计 过 程 
创建 脚本 文件 index.php。 通 过 <table> 标 签 编写 网 页 文件 ， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 
击 “ 显 示 平 均 成 绩 ” 按 钮 时 ， 显 示 如 图 8.88 所 示 的 内 容 ， 核 心 代码 如 下 : 


?php 
if($_GET[id] = "1"){ /如 果 地 址 栏 这 等 于 1 

//SQL 语句 

$sql = "select (sclect avg(chinese) from tb_demo071).(select avg(math) from tb_demo071).(select avg(english) from tb_demo071) from 
tb_demo071"; 

Srsss = mysql_query($sql) or die ("false"); // 返 回 结果 集 

Srsst = mysql_fetch_array($rsss); 
> 


<tr><td background="pic/head.JPG"> 各 科 平 均 成 绩 </td><td background="pic/head.JPG"></td><td background="pic/head.JPG"></td><td 
background="pic/head.JPG"></td><td background="pic/head.JPG"><?php echo Srsst[0]:?></td><td background="pic/head.JPG"><?php echo 
Srsst[1]:?></td><td background="pic/head.JPG"><?php echo S$rsst[2]:?></td></tr> 
<?php 

} 
?> 


国 秘笈 心 法 


心 法 领悟 416: 方便 的 别名 。 
在 使 用 子 查询 时 最 好 为 列表 项 取 个 别名 ， 这 样 可 以 方便 用 户 在 使 用 mysql_fetch_array0 函 数 时 为 表 项 赋值 。 


561 


PHP 开发 实例 大 全 (基础 卷 ) 


趣味 指教 : 傅 塘 良 良 ， 


力 实例 说 明 


使 用 子 查询 关联 数据 在 实际 项 目 开发 过 程 中 被 广泛 应 用 ， 它 可 以 使 多 表 之 间 的 查询 变 得 更 加 简捷 。 运 行 本 
实例 ， 如 图 8.89 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 要 查询 的 班级 名 称 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 该 班级 
所 有 学 生 的 详细 信息 查询 出 来 。 


图 8.89 ”使 用 子 查询 关联 数据 


图 关键 技术 
本 实例 实现 使 用 子 查询 关联 数据 的 SQL 语句 如 下 : 


select * from tb_demo072_student where uid = (sclect id from tb_demo072_class where className ='$_POST[text] ): 
图 设计 过 程 

创建 脚本 文件 index.php。 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 编 写 文本 框 ， 为 文本 框 设 置 初始 值 ， 
当 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.89 所 示 的 内 容 ， 核 心 代码 如 下 : 


<?php 
if($_POST[sub]){ // 单 击 按钮 

// 返 回 结果 集 

Srs = mysql_query("select * from tb_demo072_student where uid = (select id from tb_demo072_class where className ='$_POST[text]' )"): 
> 
<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓 名 </td><td 
background="pic/head.JPG"> 学 生性 别 </td><td background="pic/head.JPG"> 语 文成 绩 </td><td background="pic/head.JPG"> 数 学 成 绩 </td><td 
background="pic/head.JPG"> 英 语 成 绩 </td></tr> 
< 

while(Srst= mysql_fetch_row(Srs){ /循环 输出 结果 


> 

<tr><td background="pic /head.JPG"><?php echo $rst[0]:?></td><td background="pic /head.JPG"><?php echo $rst[2]:?></td><td 
background="pic/head.JPG"><?php echo $rst[3]:7></td><td background="pic /head.JPG"><?php echo $rst[4]:?></td><td 
background="pic/head.JPG"><?php echo $rst[5]:?></td><td background="pic /head. JPG"><?php echo S$rst[6]:?></td><td 
background="pic/head.JPG"><?php echo $rst[7]:?></td></tr> 

<?php 


} 


} 
?> 


国 秘笈 心 法 


心 法 领悟 417: 浅 谈 本 实例 的 实现 原理 。 
本 实例 的 实现 原理 是 通过 内 查询 select id from tb_demo072_class where className = '$ POST[text]' 获 取 要 查 
询 的 班级 名 称 ， 然 后 通过 外 部 查询 获取 要 查询 班级 的 所 有 学 生 的 详细 信息 。 


第 8 章 MySQL 数据 库 与 PHP 


趣味 指教 : 容 丰 机 页 ， 


力 实例 说 明 


多 表 联合 查询 可 以 解决 连接 或 简单 子 查询 难于 处 理 的 问题 。 运 行 本 实例 ， 如 图 8.90 所 示 ， 单 击 图 中 的 “ 合 
并 学 生 信息 ”按钮 ， 即 可 将 所 有 的 学 生 信息 合并 输出 。 


ELSD 
2010-07-26 
2010-07-17 


图 8.90 多 表 联 合 查询 


力 关键 技术 


利用 SQL 语言 中 的 关键 字 union， 可 以 将 不 同 表 中 符合 条 件 的 数据 信息 显示 在 同一 列 中 。union 语句 的 使 用 
RR heifieadonlS [query pecifiealion2 J union [all] <auery specifieationlS [uery specifieationy:] 

参数 说 明 : 

<query specification1>: 是 查询 规范 或 查询 表达 式 。 

union: 组 合 多 个 结果 集 并 将 其 作为 单个 结果 集 返 回 。 

all: 在 结果 集中 包含 所 有 的 行 ， 包 含 重复 行 。 


图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 合 并 学 生 信息 ”按钮 时 ， 显 
示 如 图 8.90 所 示 的 内 容 ， 核 心 代码 如 下 : 

<?php 


if($_GET[id] = "1){ // 如 果 地 址 栏 id 等 于 1 
S$rs = mysql_query("select * from tb_demo074_student union select * from tb_demo074_fasten"): /返回 结果 集 
?> 
<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓 名 </td><td 
background="pic/head.JPG"> 入 学 时 间 </td></tr> 
<?php 
while($rst = mysql fetch_row($rs){ /| 循环 输出 结果 


<tr><td background—"pic /head JPG"><?php echo $rst[0]:7></td><td background="pic/head JPG"><?php echo Srst[1]:7></d><td 
background="pic/head.JPG"><?php echo $rst[2]:7></td></tr> 
?php 


S 
?> 


PHP 开发 实例 大 全 (基础 卷 ) 


心 法 领悟 418: 使 用 union 关键 字 的 注意 事项 。 

(1) 在 使 用 union 运算 符 组 合 的 语句 中 ， 所 有 选择 列表 的 表达 式 数目 必须 相同 ， 如 列 名 、 算 术 表达 式 及 聚 
合 函数 等 。 

(2) 在 每 个 查询 表 中 ， 对 应 列 的 数据 必须 是 同一 数据 类 型 。 


力 实例 说 明 


为 了 与 union 运算 兼容 ， 要 求 所 有 select 语句 都 不 能 有 order by 子 句 ， 但 有 一 种 情况 例外 ， 那 就 是 在 最 后 一 
个 select 语句 中 放置 order by 子 句 实现 结果 的 最 终 排序 输出 。 运 行 本 实例 ， 如 图 8.91 所 示 ， 单 击 图 中 的 “合并 
学 生 信息 ”按钮 ， 即 可 将 所 有 的 学 生 信 息 合并 ， 并 按 入 学 时 间 降 序 输出 。 


对 联合 查询 结果 进行 排序 


图 关键 技术 


本 实例 实现 对 联合 查询 结果 进行 排序 ，SQL 语句 如 下 : 


select * from tb_demo074_student union select * from tb_demo074_fasten order by date desc: 
图 设计 过 程 

创建 脚本 文件 index.php。 开 启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 单 击 “合并 学 生 信息 ”按钮 时 ， 显 
示 如 图 8.91 所 示 的 内 容 ， 核 心 代码 如 下 : 


<?php 
if($_GET[id] = "1"){ // 如 果 地 址 栏 参数 id 等 于 1 
Srs = mysql_query("select * from tb_demo074_student union select * from tb_demo074_fasten order by date desc"): // 返 回 结果 集 
> 
<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head.JPG"> 学 生 姓 名 </td><td 
background="pic/head.JPG"> 入 学 时 间 </td></tr> 
<?php 
while($rst = mysql_fetch_row($rs)){ /循环 输出 结果 
> 
<tr><td background="pic/head.JPG"><?php echo Srst[01:?></td><td background="pic/head. JPG"><?php echo Srst[11:?></td><td 
background="pic/head.JPG"><?php echo $rst[2]:?></td></tr> 
<?php 
} 


> 
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心 法 领悟 419: 使 用 union 关键 字 虽 然 可 以 将 所 有 的 查询 结果 合并 到 一 起 ， 但 是 会 去 除 相同 记录 ， 如 果 想 合 
并 所 有 查询 结果 需要 使 用 all 关键 字 ，all 关键 字 的 作用 是 在 结果 集中 包含 所 有 的 行 并 且 包 含 重复 行 。 


EE 


图 实例 说 明 

本 实例 将 应 用 group by 分 组 语句 和 having 语句 实现 条 件 联合 查询 。 运 行 本 实例 ， 如 图 8.92 所 示 ， 单 击 图 
中 的 “出 版 社 信息 ”按钮 ， 即 可 将 全 国 各 个 大 型 出 版 社 的 名 单 显示 出 来 ， 并 保证 人 民 邮 电 出 版 社 和 机 械 工 业 出 
版 社 始终 位 于 名 单 最 前 列 。 


经 大 ， 
请 华 大 学 出 级 社 


8.92 ”条件 联 合 语句 


图 关键 技术 


本 实例 的 条 件 联合 语句 中 , 首先 按 出 版 社 名 称 (name) 进行 分 组 , 然后 利用 having 子 句 限定 条 件 , 如 having 
name=' 人 民 邮 电 出 版 社 ' or name=' 机 械 工 业 出 版 社 '， 这样， 执行 结果 将 显示 出 人 民 邮 电 出 版 社 和 机 械 工 业 出 版 社 
这 两 条 记录 ， 最 后 用 union all 运算 符 与 另 一 个 数据 表 合 并 ， 并 利用 having 限定 条 件 (having name<>' 人 民 邮 电 
出 版 社 ' and name<>' 机 械 工 业 出 版 社 ') ， 即 可 调 出 出 版 社 的 名 称 ， 并 且 确 保 人 民 邮 电 出 版 社 和 机 械 工业 出 版 社 
始终 位 于 名 单 最 前 列 。 本 实例 中 实现 联合 查询 的 代码 如 下 : 


select name 他 om tb_demo076_Beijing group by name having name=' 人 民 邮 电 出 版 社 ' or name= 机 械 工 业 出 版 社 ' union all select name from 
也 _demo076_Beijing group by name having name<>' 人 民 邮 电 出 版 社 'and name<>" 机 械 工业 出 版 社 ' 


力 设计 过 程 

编写 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 出 版 社 信息 ”按钮 时 ， 显 示 如 
图 8.92 所 示 的 内 容 。 本 实例 的 核心 代码 如 下 : 

<?php 

if($_GET[id] = "1"){ // 单 击 按钮 

Srs = mysql_query("select name from tb_demo076_Beijing group by name having name=' 人 民 邮 电 出 版 社 'or name=' 机 械 工业 出 版 社 'union al 

select name from tb_demo076_Beijing group by name having name<>' 人 民 邮 电 出 版 社 ' and name<>' 机 械 工 业 出 版 社 "): “// 返 回 结果 集 

?> 

<table width="580px"><tr><td background="pic/head.JPG" align="center"> 出 版 社 信息 </td></tr> 

while($rst = mysql_fetch_row($rs)){ // 循 环 输出 结果 


?> 
<tr><td background="pic/head.JPG" align="center"><?php echo $rst[0]:?></td></tr> 
<?php 

} 
} 
> 
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心 法 领悟 420: having 子 句 。 
本 实例 使 用 了 having 子 句 限定 条 件 ， 对 having 子 句 的 详细 说 明 会 在 后 面 的 实例 中 详细 介绍 。 


图 实例 说 明 


通常 利用 内 连接 将 两 个 表 或 多 个 表 连 接 起 来 实现 某 些 特定 的 功能 。 本 实例 通过 内 连接 将 学 生 信息 表 和 学 生 
成 绩 表 连 接 起 来 ,实现 将 学 生 信 息 和 学 生成 绩 同时 显示 出 来 。 运行 本 实例 ， 如 图 8.93 所 示 ， 单 击 图 中 的 “查询 ” 
按钮 ， 即 可 将 所 有 学 生 的 基本 信息 和 成 绩 情况 显示 出 来 。 


图 8.93 ”内 连接 查询 


图 关键 技术 


SQL 语言 中 ， 实 现 内 连接 的 基本 语法 格式 如 下 : 


Sselect ficldlist from tablel [inner] join table2 on tablel.column1=table2.columnl 
其 中 ，fieldlist 为 要 查询 的 字段 列表 ，tablel 和 table2 为 要 连接 的 表 名 ， 谓 词 inner 表示 表 之 间 的 连接 方式 
为 内 连接 ，tablel.column1=table2.column1 用 于 指明 表 tablel 和 表 table2 之 间 的 连接 条 件 。 


图 设计 过 程 
编写 文件 index.php， 通 过 内 连接 方式 实现 学 生 信息 表 和 学 生成 绩 表 的 连接 ， 并 显示 查询 结果 ， 代 码 如 下 : 
arta mT // 单 击 按钮 
Srs = mysql_query("select tb_demo065.name.tb_demo065.address.tb_demo065.date.tb_demo065_tel.math.tb_demo065_tel.english.tb_demo065_ 
tel.chinese from tb_demo065 inner join tb_demo065 _tel on tb_demo065.id=tb_demo065_teLid"): /返回 结果 集 


?> 
<table width="580px"><tr><td background="pic/head.JPG" align="center"> 学 生 姓 名 </td><td background="pic/head.JPG" align="center"> 家 庭 住址 
</td><td background="pic/head.JPG" align="center"> 入 学 日 期 <ltd><td background="pic/head.JPG" align="center"> 数 学 成 绩 </td><td 
background="pic/head.JPG" align="center"> 英 语 成 绩 </td><td background="pic/head.JPG" align="center"> 语 文成 绩 </td></tr> 
<?php 

while(Srst = mysql_fetch_row($rs)){ /循环 输出 结果 


> 

<tr><td background="pic/head. JPG" align="center"><?php echo Srst[0]:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[1]:?></td><td background="pic/head.JPG" align="center"><?php echo $rst[2]:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[31:?></td><td background="pic/head JPG" align="center"><?php echo $rst[4]:?></td><td background="pic/head JPG" align="center"><?php echo 
Srst[5]:?></td></tr> 

<Iphp 
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心 法 领悟 421: 多 表 查 询 实现 的 方法 。 
本 实例 使 用 的 内 连接 只 是 SQL 语句 的 一 种 方法 ， 此 方法 可 以 使 用 多 表 查 询 的 知识 实现 相同 的 功能 。 使 用 多 
表 查 询 的 SQL 语句 的 代码 如 下 


Select a.name,a.address.a.date,b.math.b.english.b.chinese from tb demo065 as atb demo065 tel asb where a.id=b.id; 


2 Se 


力 实例 说 明 


在 实际 项 目 开发 过 程 中 ， 所 应 用 的 内 连接 查询 大 多 都 是 较 复杂 的 ， 例 如 对 多 张 表 通过 内 连接 方式 建立 关联 
后 , 还 需要 在 SQL 语句 中 再 指明 一 些 查询 条 件 , 从 而 进一步 实现 查询 的 精确 定位 。 运行 本 实例 , 如 图 8.94 所 示 ， 
首先 在 图 中 的 文本 框 中 输入 要 查询 的 员工 编号 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 所 要 查询 的 员工 的 基本 信息 和 
工资 状况 查询 出 来 。 


2010-07-26 


图 8.94 复杂 的 内 连接 查询 


图 关键 技术 


复杂 的 内 连接 查询 是 在 基本 内 连接 查询 的 基础 上 再 附加 一 些 查询 条 件 ， 例 如 本 实例 中 实现 查询 员工 基本 信 
息 情 况 的 代码 如 下 : 


select tb_demo078_wages. Wages.tb_demo078_informaction.name.tb_demo078_informaction.sex.tb_demo078 Spi date from 
tb_demo078_wages inner join tb_demo078_informaction on tb_demo078_wages.id=tb_demo078_informaction.id 
tb_demo078_informaction.id=(sclect id from tb_demo078_id where code='$_POST[text]): 


图 设计 过 程 


创建 脚本 文件 index.php， 开 启 MySQL 服务 ， 连 接 MySQL 数据 库 。 编 写 <form> 表 单 ， 当 单 击 “ 查 询 ” 按 
钮 时 ， 显 示 如 图 8.94 所 示 的 内 容 ， 核 心 代码 如 下 : 


<?php 
if($_POST[sub) { // 单 击 按钮 

Srs = mysql_query("select tb_demo078_wages.Wages.tb_demo078_informaction .name.tb_demo078_informaction.sex,tb_demo078_informaction 
.date from tb_demo078_wages inner join tb_demo078_informaction on tb_demo078_wages.id=tb_demo078_informaction.id where tb_demo078_ 
informaction.id=(select id from tb_demo078_id where code='$ POST[text])"): // 返 回 结 果 集 
?> 
<table width="580px"><tr><td background="pic/head.JPG" align="center"> 员 工 姓名 </td><td background="pic/head.JPG" align="center"> 员 工 性 别 
</td><td background="pic/head.JPG" align="center"> 入 职 时 间 </td><td background="pic/head.JPG" align="center"> 员 工 工资 </td></tr> 


while(S$rst = mysql_fetch_row($rs){ /循环 输出 结果 


?> 

<tr><td background="pic/head.JPG" align="center"><?php echo $rst[1]:?></td><td background="pic/head. JPG" align="center"><?php echo 
Srst[2]:?></td><td background="pic/head JPG" align="center"><?php echo S$rst[3]:7?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[0]:?></td></tr> 

<php 
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} 
} 
> 


心 法 领悟 422: 如 何 选 择 SQL 语句 查询 的 方法 。 
实现 复杂 SQL 语句 查询 的 方法 有 很 多 ， 而 且 彼此 实现 的 功能 相同 ， 至 于 选择 哪 种 方法 ， 则 由 用 户 或 程序 员 
的 个 人 喜好 决定 。 


高 级 
起 味 指数 : 裕 宙 页 页 | 


实例 423 


图 实例 说 明 


建立 表 与 表 之 间 的 关联 是 PHP 程序 员 在 设计 数据 库 时 都 会 遇 到 的 问题 ， 而 两 表 之 间 的 关联 在 中 小 型 网 站 中 
出 现 的 频率 是 最 高 的 。 运 行 本 实例 ， 在 图 8.95 所 示 界 面 的 文本 框 中 输入 员工 工资 ， 单 击 “查询 ”按钮 ， 即 可 显 
示 与 文本 框 关联 的 所 有 内 容 。 


4010-07-26 


图 8.95 两 表 的 内 连接 关联 


图 关键 技术 
本 实例 实现 两 表 关联 的 SQL 语句 如 下 : 


select tb_demo078_id.code.,tb_demo078_informaction.name.tb_demo078_informaction.sex.tb_demo078_informaction.date from tb_demo078_id inner 
join tb_demo078_informaction on tb_demo078_id.id =tb_demo078_informaction.id where tb_demo078_informaction.id=(select id from 
tb_demo078_wages where Wages ='$_POST[text]): 


图 设计 过 程 
编写 脚本 文件 index.php， 开 启 MySQL 服务 ， 连 接 MySQL 数据 库 ， 当 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.95 
所 示 的 内 容 ， 核 心 代码 如 下 : 


<Iphp 

这 $_POST[sub]){ 

Srs = mysql_query("select th_demo078_id.code.tb_demo078_informaction.name.tb_demo078_informaction.sex.tb_demo078_informaction.date from 
th_demo078_id inner join th_demo078_informaction on tb_demo078_id.id =tb_demo078_informaction.id where tb_demo078_informaction.id=(select 
id from tb_demo078_wages where Wages ='$_POST[text])"): 

> 

<table width="580px" bgcolor="#FF9FDF"><tr><td style="color: 皇 FFFFF" align="center"> 员 工 姓名 </td><td style="color: 托 FFFFF" align="center"> 
员工 性 别 <hd><td style="color: 纯 FFFFF" align="center"> 入 职 时 间 </td><td style="ecolorsFFFFFF" align="center"> 员 工 编号 <ltd></tr> 

<?php 

while(Srst = mysql_fetch_row($rs)){ 

?> 


<tr><td bgcolor="#F FFFFF" align="center"><?php echo $rst[11:7></td><td bgcolor="#FFFFFF" align="center"><?php echo $rst[21:?></td><td 
bgeolor="#FFFFFF" align="center"><?php echo $rst[3]:?></td><td bgcolor="#FFFFFF" align="center"><?php echo $rst[0]:?></td></tr> 
<php 

} 

} 


> 


第 8 章 ”MySQL 数据 库 与 PHP 


心 法 领悟 423: 浅 谈 两 表 关联 的 本 质 。 
实现 表 与 表 之 间 关 联 的 本 质 是 两 表 之 间 存 在 共同 的 数据 项 或 者 相同 的 数据 项 ， 通 过 where 子 句 或 内 连接 
inner join.…on 语句 将 两 表 连接 起 来 ， 实 现 查 询 。 


高 级 | 


实例 424 趣味 指教 : 傅 禄 请 良 | 


力 实例 说 明 


外 连接 查询 在 数据 库 系统 开发 过 程 中 应 用 较为 广泛 ， 运 行 本 实例 ， 如 图 8.96 所 示 ， 单 击 图 中 的 “查询 ” 按 
钮 ， 即 可 通过 外 连接 的 方式 将 所 有 员工 的 信息 显示 出 来 。 


2010-07-26 
2010-07-26 
2010-07-26 


图 8.96 使 用 外 连接 多 表 查 询 


图 关键 技术 
本 实例 中 通过 外 连接 查询 的 代码 如 下 : 


select tb_demo078_wages. Wages.tb_demo078_informaction.name,tb_demo078_informaction.sex,tb_demo078_informaction.date from tb_demo078_ 
wages left outer join tb_demo078_informaction on tb_demo078_wages.id =tb_demo078_informaction.id 


图 设计 过 程 


创建 脚本 文件 index.php， 连 接 MySQL 数据 库 ， 当 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.96 所 示 的 内 容 。 本 实 


例 的 核心 代码 如 下 : 
这 $_GET[idl 一 "19{ / 漳 击 按钮 


Srs = mysql_query("select tb_demo078_wages.Wages.tb_demo078_informaction.name.tb_demo078_informaction.sex.tb_demo078_informaction 
date from tb_demo078_wages left outer join tb_demo078_informaction on tb_demo078_wages.id =tb_demo078_informaction.id"); ”// 返 回 结果 集 
?> 
<table width="580px"><tr><td background="pic/head.JPG" align="center"> 员 工 姓名 </td><td background="pic/head.JPG" align="center"> 员 工 性 别 
</td><td background="pic/head.JPG" align="center"> 入 职 时 间 </td><td background="pic/head.JPG" align="center"> 员 工 工资 </td></tr> 
?php 

while($rst = mysql_fetch_row($rs){ /| 循环 输出 结果 
?> 
<tr><td background="pic/head.JPG" align="center"><?php echo S$rst[1]:?></td><td background="pic/head. JPG" align="center"><?php echo 
Srst[2]:?></td><td background="pic/head.JPG" align="center"><?php echo S$rst[3]:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[0]:?></td></tr> 
<php 


} 
} 
?> 


国 秘笈 心 ; 


心 法 领悟 424: 理解 left outer join。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


left outer join 表示 建立 表 tb_ yg 和 tb_yg_info 的 外 连接 。 


力 实例 说 明 


如 果 要 包含 连接 的 两 个 表 中 的 不 匹配 行 ， 可 以 通过 左 连 接 或 右 连 接 的 方式 实现 。 运 行 本 实例 ， 如 图 8.97 所 
示 ， 单 击 图 中 的 “查询 ”按钮 ， 即 可 将 员工 信息 表 中 的 所 有 记录 以 及 员工 工资 表 中 与 员工 ID 相 匹 配 的 记录 显示 
出 来 。 


200-07-25 
2010-07-26 
2010-07-26 


图 8.97 ”left outer join 查询 


图 关键 技术 


左 连接 返回 的 查询 结果 包含 左 表 中 的 所 有 符合 查询 条 件 及 右 表 中 所 有 满足 连接 条 件 的 行 , MySQL 数据 库 中 
使 用 左 连接 的 语法 格式 如 下 : 

select ficld 1[ficld2...] from tablel left [outer] join table2 on join_condition [where scarch_condition] 

参数 说 明 : 

left outer join: 表示 表 之 间 通 过 左 连接 方式 相互 连接 ， 也 可 以 简写 成 leftjoin。 

join_condition: 指 多 表 建 立 连 接 所 使 用 的 连接 条 件 。 

where search_condition: 可 选项 ， 用 于 设置 查询 条 件 。 


图 设计 过 程 
编写 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 查 询 ”按钮 时 ， 显示 如 图 8.97 


所 示 的 内 容 ， 核 心 代码 如 下 : 
if($_GET[id] = "1"){ /| 单 击 按钮 
Srs = mysql_query("select * from tb_demo078_informaction left outer join tb_demo078_wages on tb_demo078_wages.id= 
tb_demo078_informaction.id "); // 返 回 结果 集 
?> 
<table width="580px"><tr><td background="pic/head.JPG" align="center"> 员 工 姓名 </td><td background="pic/head.JPG" align="center"> 员 工 性 别 
</td><td background="pic/head.JPG" align="center"> 入 职 时 间 </td><td background="pic/head.JPG" align="center"> 员 工 工资 </td></tr> 
while($rst = mysql_feteh_row($rs){ /| 循环 输出 结果 
?> 
<tr><td background="pic/head.JPG" align="center"><?php echo $rst[1]:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[2]:?></td><td background="pic/head.JPG" align="center"><?php echo $rst[3]:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[5]:?></td></tr> 
php 


上 


> 


力 秘笈 心 法 
心 法 领悟 425: 对 左 连接 的 理解 。 
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左 连接 以 left outer join 左 侧 的 表 名 为 基准 ， 所 以 称 左 连接 ， 左 侧 表 名 的 所 有 信息 将 被 全 部 输出 ， 符 合 条 件 
的 右 侧 表 信 息 也 会 被 输出 ， 如 果 不 符合 条 件 ， 返 回 NULL。 


高级 


i 
1 
起 听 指 数 寅 机 od 


实例 426 


力 实例 说 明 


通过 右 连 接 可 以 将 右 表 中 满足 查询 条 件 的 记录 全 部 显示 出 来 ， 并 显示 左 表 中 满足 连接 条 件 的 记录 。 运 行 本 
实例 ， 如 图 8.98 所 示 ， 单 击 图 中 的 “查询 ”按钮 ， 即 可 将 员工 信息 表 中 满足 连接 条 件 的 记录 及 员工 工资 表 中 所 
有 记录 全 部 显示 出 来 。 


el 让 join 棕 询 


EUR 
20-07-25 


图 8.98 right outer join 查询 


力 关键 技术 


右 连接 返回 的 查询 结果 包含 左 表 中 的 所 有 符合 连接 条 件 以 及 右 表 中 所 有 满足 查询 条 件 的 行 , MySQL 数据 库 
中 使 用 右 连 接 的 语法 格式 如 下 : 


| 
参数 说 明 : 

right outer join: 表示 表 之 间 通 过 右 连接 方式 相互 连接 ， 也 可 以 简写 成 right join。 
join_condition: 指 多 表 建 立 连 接 所 使 用 的 连接 条 件 。 

where search_condition: 可 选项 ， 用 于 设置 查询 条 件 。 


力 设计 过 程 
编写 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.98 
所 示 的 内 容 。 本 实例 的 核心 代码 如 下 : 


if($_GET[id] = "1"){ // 单 击 按钮 

Srs = mysql_query("select * from tb_demo078_wages right outer join tb_demo078_informaction on tb_demo078_wages.id=tb_demo078 
informaction id "); /返回 结果 集 
?> 


<table width="580px"><tr><td background="pic/head.JPG" align="center"> 员 工 姓名 </td><td background="pic/head.JPG" align="center"> 员 工 性 别 
</td><td background="pic/head.JPG" align="center"> 入 职 时 间 </td><td background="pic/head.JPG" align="center"> 员 工 工资 </td></tr> 


while($rst = mysql_fetch_row($rs){ // 循 环 输出 结果 


<tr><td background="pic /head.JPG" align="center"><?php echo $rst[3]:7?></td><td background="pic /head.JPG" align="center"><?php echo 
Srst[4]:?></td><td background="pic /head.JPG" align="center"><?php echo $rst[5]:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[1]:?></td></tr> 
<Iphp 

} 
} 
> 
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心 法 领悟 426: 对 右 连接 的 理解 。 
右 连 接 以 right outer join 右 侧 的 表 名 为 基准 ， 所 以 称 右 连接 ， 右 侧 表 名 的 所 有 信息 将 被 全 部 输出 ,符合 条 件 
的 左 侧 表 信 息 也 会 被 输出 ， 如 果 不 符合 条 件 则 返回 NULL。 


A 高 级 
实例 427 趣味 指教: obolololl 
图 实例 说 明 


利用 关键 字 in 或 notin 可 以 限定 查询 范围 ， 运 行 本 实例 ， 如 图 8.99 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 要 查 
询 学 生成 绩 的 学 号 范围 ， 然 后 单 击 “查询 ”按钮 ， 即 可 将 该 范围 内 的 所 有 学 生 的 各 科 成 绩 查 找 出 来 。 


请 输入 学 号 范围 ， 
学 生 编 号 学 生 姓 名 
1081 小 杨 


1015 小 刘 
1026 小 潘 


8.99 ”利用 加 关键 字 限定 范围 


图 关键 技术 


本 实例 中 ， 利 用 关键 字 in 查询 指定 学 号 范围 内 的 学 生成 绩 ， 代 码 如 下 : 


select * from tb_demo083 where code in (sclect code from tb_demo083 where code between '$_POST[te]' and '$_POST[tex]); 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 并 连接 MySQL 数据 库 。 编 写 form 表单 ， 当 单 击 “查询 ”按钮 
时 ， 显 示 如 图 8.99 所 示 的 内 容 。 核 心 代码 如 下 : 


if($_POST[sub) { / 单 击 按钮 

Srs = mysql_query("select * from tb_demo083 where code in (select code from tb_demo083 where code between '$_POST[te] and 
'$_POST[tex])"); // 返 回 结果 集 
?> 


<table width="580px"><tr><td background="pic/head.JPG" align="center"> 学 生 编 号 </td><td background="pic/head.JPG" align="center"> 学 生 姓名 
</td><td background="pic/head.JPG" align="center"> 语 文成 绩 </td><td background="pic/head.JPG" align="center"> 数 学 成 绩 </td><td 
background="pic/head.JPG" align="center"> 英 语 成 绩 </td></tr> 


while($rst = mysql_feteh_row($rs){ // 循 环 输出 结果 
> 
<tr><td background="pic/head.JPG" align="center"><?php echo S$rst[1]:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[2]:?></td><td background="pic/head. JPG" align="center"><?php echo Srst[3]:?></td><td background="pic/head. JPG" align="center"><?php echo 
Srst[4]:?></td><td background="pic/head JPG" align="center"><?php echo $rst[5]:?></td></tr> 
<Iphp 

| 
} 


> 


国 秘笈 心 法 
心 法 领悟 427: 如 何 书写 不 在 指定 范围 的 SQL 语句 代码 。 
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在 本 实例 的 SQL 语句 中 ， 如 果 想 查找 不 在 指定 范围 内 的 所 有 信息 ， 可 以 将 in 改 为 notin。 


实例 428 


力 实例 说 明 


SQL 语言 中 ， 可 以 利用 关键 字 in 来 查询 表 中 满足 一 定 条 件 的 记录 。 运 行 本 实例 ， 如 图 8.100 所 示 ， 首 先 在 
图 中 的 文本 框 中 输入 要 查询 的 图 书 名 称 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 与 用 户 输 入 的 查询 关键 字 相 匹 配 的 图 
书 查找 出 来 。 


《 各 工业 出 版 社 
《PR 范例 实 刻 宝 下 》 清华 天 学 由 版 社 明日 科技 


图 8.100 用 in 查询 表 中 记录 


图 关键 技术 


本 实例 首先 通过 in 子 查询 查找 出 所 有 与 用 户 输入 的 关键 字 相 匹配 的 图 书 名 称 ， 然 后 通过 外 部 查询 查找 出 所 
有 图 书 的 详细 信息 ， 代 码 如 下 : 

select * from tb_demo084 where name in (select name from tb_demo084 where name like '%$_POST[te]%'; 
图 设计 过 程 

创建 脚本 文件 index.php。 编 写 网 页 框架 ， 开 启 MySQL 服务 ， 连 接 MySQL 数据 库 。 编 写 form 表单 ， 当 单 
击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.100 所 示 的 内 容 ， 核 心 代码 如 下 : 


<?php 
这 $_POST[sub]){f / 单 击 按钮 
这 $_POST[te] 一 "||$_POST[te] 一 "输入 关键 字 "){ 1/ 对 文本 框 信息 进行 判断 
echo "<script>alert(' 请 输入 内 容 );</script>": //JavaScript 提示 
Jelse{ 
$sql = "select * from tb_demo084 where name in (select name from tb_demo084 where name like '%$_POST[te]%') "; /SQL 语句 
Srs = mysql_query($sqD: /返回 结果 集 


?> 

<table width="580px"><tr><td background="pic/head.JPG" align="center"> 图 书 编号 </td><td background="pi 
align="center"> 图 书 名 称 </td><td background="pic/head.JPG" align="center"> 出 版 社 </td><td background="pic/head.JPG" i ee 
<ltd><ltr> 
<?php 

while($rst = mysql_fetch_row($rs){ /| 循环 输出 结果 


<tr><td background="pic/head.JPG" align="center"><?php echo $rst[0]:?></td><td background="pic/head.JPG" align="center"><?php 
echo $rst[1]:?></td><td background="pic/head JPG" align="center"><?php echo $rst[2]:?></td><td background="pic/head.JPG" align="center"><?php 


国 秘笈 心 法 
心 法 领悟 428: 实现 实例 的 其 他 方法 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


在 上 面 的 实例 中 已 经 提 到 过 ，SQL 语句 有 很 多 种 形式 , 而 且 不 同 的 SQL 语句 形式 可 以 完成 相同 的 功能 ， 本 
实例 使 用 关键 技术 中 的 SQL 语句 未 免 有 些 麻烦 ， 实 现 此 功能 的 简单 SQL 语句 如 下 : 


Select * from tb_demo084 where name like '%$_ POST[te]%'; 


a 高 级 | 
实例 429 趣味 指数 : id 
国 实例 说 明 


本 实例 实现 利用 SQL 语言 中 的 关键 字 in 查找 在 职 或 离职 的 员工 信息 。 运 行 本 实例 ， 如 图 8.101 所 示 ， 首 先 在 
图 中 的 单 选 按钮 中 选择 员工 的 在 岗 情 况 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 即 可 将 所 有 在 职 或 离职 的 员工 信息 显示 出 来 。 


图 8.101 由 in 引入 的 关联 子 查询 


图 关键 技术 
由 关键 字 in 引入 的 关联 子 查询 的 语法 格式 如 下 : 


rs 

参数 说 明 : 

column name list， 要 查询 的 列 名 。 

table list; 查询 所 涉及 的 表 名 。 

test expression: 查询 条 件 。 

subquery: 子 查询 。 

本 实例 使 用 关键 字 in 实现 关联 子 查 询 ，SQL 语句 如 下 : 

select * from tb_demo085 where work in (select work from tb_demo085 where work='$_POST[click]': 
图 设计 过 程 

创建 脚本 文件 index.php， 开 启 MySQL 服务 ， 连 接 MySQL 数据 库 。 当 单 击 “ 查 询 ” 按 钮 时 显示 如 图 8.101 
所 示 的 内 容 ， 核 心 代码 如 下 : 

<?php 


$conn = mysql_connect("localhost", "root","111"): // 连 接 MySQL 


mysql_select_db("db_database08".$conn): /连接 MySQL 数据 库 
mysql_query("SET NAMES UTF8"): // 设 置 编码 集 
if($_POST[sub){ // 单 击 按钮 


S$rs = mysql_query("select * from tb_demo085 where work in (select work from tb_demo085 where work='$_POST[click])"); // 返 回 结果 集 
?> 
<table width="580px"><tr><td background="pic/head.JPG" align="center"> 员 工 ID</td><td background="pic/head.JPG" align="center"> 员 工 姓名 
</td><td background="pic/head.JPG" align="center"> 家 庭 住 址 </td><td background="pic/head.JPG" align="center"> 是 否 在 职 </td></tr> 
<Iphp 

while($rst = mysql_fetch_row($rs){ /循环 输出 结果 

?> 
<tr><td background="pic/head.JPG" align="center"><?php echo S$rst[0]:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[11:?></td><td background="pic/head.JPG" align="center"><?php echo S$rst[21:?></td><td background="pic/head.JPG" align="center"><?php echo 
Srst[3]:?></td></tr> 


第 8 章 MySQL 数据 库 与 PHP 


<php 
} 


心 法 领悟 429: 关键 字 in 的 重要 性 。 
关键 字 in 在 单 表 查询 中 被 广泛 使 用 ， 熟 练 掌握 此 关键 字 对 于 PHP 程序 员 来 说 是 十 分 必要 的 。 


力 实例 说 明 


利用 transform 可 以 动态 地 按照 类 别 或 分 组 统计 出 所 需要 的 数据 。 运 行 本 实例 ， 如 图 8.102 所 示 ， 单 击 “ 统 
计 ” 按 钮 ， 即 可 按 月 份 将 不 同 种 类 图 书 的 数量 统计 出 来 。 


8.102 ”利用 transform 分 析 数 据 


图 关键 技术 


本 实例 中 利用 transform 创建 交叉 表 查 询 , 使 之 能 按 月 份 统计 不 同名 称 图 书 的 数量 。transform 的 语法 格式 如 下 : 
Ee 
pivot pivotficld [in (valuel[value2]..[valuenJ)] 


参数 说 明 : 

aggfunction: 操作 所 选 数据 库 的 SQL 聚合 函数 。 

select statement: 要 执行 的 select 语句 。 

pivotfield: 希望 用 于 创建 查询 结果 集中 列 标题 的 字段 或 表达 式 。 
valuel...valuen: 用 于 创建 列 标题 的 固定 值 。 


看 设计 过 程 

(1) 建立 conn php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 
区 "adodb.connection"): // 连 接 数 据 库 
S$connstr="provider=microsoftjet.oledb.4.0:data source=".realpath("./data/db_database08.mdb"); 
ey 

5 执行 查询 并 显示 查询 结果 ， 代 码 如 下 : 
<2php 

include("conn.php"); // 包 含 数据 库 连 接 文 件 


PHP 开发 实例 大 全 (基础 卷 ) 


Srs->open("transform sum(number) as total select yyassort from tb_booksort where yyassort in (select yyassort from tb_booksort) group by 


yyassort pivot analysetime", $conn.3,1): 


(Srs->eofll S$rs->bof){ 
> 
<tr> 
<td height="25" colspan="8" bgcolor="yellow"><div align="center"></div></td> 
< 


<?php 
} else{ 
while(!S$rs->eof){ 
> 


<t> 
<?php 
for($i=0;$i<=$rs->fields->count-1;$iH+){ 
?> 


<td height="25" bgcolor="H#FFFFFF"><div align="center"><?php $f=S$rs->ficlds($i); echo iconv('gbk','utf-8',$f->value)?></div></td> 
<?php 


?> 


<htable><ltd> 


<t> 
</table> 
<?php 


图 秘笈 心 法 


实例 431 


心 法 领悟 430: transform 的 局 限 性 。 
transform 的 实用 性 不 是 很 强 ， 而 且 只 有 在 Access 数据 库 中 有 较 好 的 支持 。 


实例 说 明 


利用 transform 可 以 方便 地 对 数据 进行 统计 。 运 行 本 实例 ， 如 图 8.103 所 示 ， 其 中 第 一 列 为 该 企业 中 不 同 部 
门 的 名 称 ， 第 一 行为 某 年 中 不 同 的 季度 ， 通 过 这 种 坐标 关系 可 以 很 方便 地 使 用 户 查看 指定 部 门 在 特定 季度 的 商 


品 销售 额 。 


8.103 ”利用 transform 动态 分 析 数 据 


图 关键 技术 
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transform 的 具体 使 用 格式 在 实例 430 中 已 经 做 了 详细 介绍 ， 这 里 不 再 袭 述 。 本 实例 中 实现 按 季 度 统计 商品 


趣味 指数 : 裕 全 全 全 : 
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信息 的 代码 如 下 : 


Srs->open("transform xs select bm from tb_xs where bm in(select bm from tb_xs) group by bm pivot xs".Sconn,3,1); 


图 设计 过 程 


(1) 建立 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 


<?php 
Sconn=new com("adodb.connection"): 


// 连 接 数 据 库 


S$connstr="provider=microsoft.jet.oledb.4.0:data source=".realpath("./data/db_database08.mdb"): 
S$conn->open($connstr); 


?> 


(2) 统计 不 同 部 门 前 三 个 季度 的 销售 额 并 显示 统计 结果 ， 代 码 如 下 : 


<?php 
i // 包 含 数据 库 连接 文件 


Srs->open("transform xs 本 xs where bm in(select bm from tb xs) group by bm pivot xs",$conn,3,1); 


if($rs->eofl| $rs->bof){ 
> 


<t> 
<td height="25" colspan="8" bgcolor="#FFFFFF"><div align="center"></div></td> 
< 
<?php 
jelsef 
while(!S$rs->eof){ 
> 


<tr> 
<2php 
for($i=0;$i<=$rs->fields->count-1:$i++){ /循环 语句 
SSrs->ficlds($i: 
if(Sf->value!="){ 


?> 
iv ali i "gbk","utf-8",$f->value)?></div></td> 


<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo iconv("gbk 
<?php 


心 法 领悟 431: transform 具有 局 限 性 ， 见 实例 430。 


实例 432 


钦 查 询 条 件 的 数据 类 型 


力 实例 说 明 


本 实例 将 利用 format0 函 数 实现 日 期 的 格式 化 输出 ， 由 于 该 函数 只 适用 于 Access 数据 库 ， 所 以 本 实例 将 以 


趣味 指教 : 请 食 傅 良 | 


OO 


高 级 | 


vod 
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Access 作为 后 台数 据 库 。 运 行 本 实例 ， 如 图 8.104 所 示 ， 单 击 图 中 的 “转换 ”按钮 即 可 将 内 容 显示 出 来 ， 并 将 
日 期 格式 由 “xxxx-xx-xx” 转 换 为 “xxxx 年 xx 月 xx 日 ”。 


站 “放生 量 “类 别 进贡 日 其 
Te Paac 500 并 下 必 法相 SI 和 实 。 4。 1 实 网 。 2004 下 mo1 昌 
Vismal Phsr 光 和 幸 开 发 安 章 S 租 4。 700 2004F 有 O16 
Ti Bei 久生 3 0 R004FAOIE 
4 和 F601 
Tan 路 权 放 高 纪 才 和 人 习 于 。 2004 于 x6 有 0IB 
新 下 纪 - 计 算 机 六 磁 教 育 从 入 % 1 M2004F5A016 
C9 入 本 儿 入 门 到 匡 天 36 20 M2004F05 有 0 
QBASI2 理 订 设 计 1 9 出 。 2004Fo4R0IB 
CC o o M2004F04AOIE 


图 8.104 格式 化 函数 转换 查询 条 件数 据 类 型 


图 关键 技术 


format0) 函 数 用 于 返回 variant(string)， 其 中 含 一 个 表达 式 ， 它 是 根据 格式 表达 式 中 的 格式 化 字符 串 来 确定 新 
格式 输出 的 。 该 函数 的 语法 格式 如 下 : 

format(expression[ ,format [firstday of week [firstweek] of year]]) 

参数 说 明 : 

expression: 必要 参数 ， 是 任何 有 效 表达 式 。 

format: 可 选 参 数 ， 是 有 效 的 命名 表达 式 或 用 户 自 定义 的 格式 表达 式 。 

firstday of week: 可 选 参 数 。 常 数 ， 表 示 一 星期 的 第 一 天 。 

firstweek of year: 可 选 参数 。 常 数 ， 表 示 一 年 的 第 一 周 。 


图 设计 过 程 
(1) 建立 conn:php 文件 实现 与 数据 库 的 连接 ， 代 码 如 下 : 


<?php 

S$conn=new com("adodb.connection"); /连接 Access 数据 库 
Sconnstr="provider=microsoftjctoledb.4.0:data source=".realpath("./data/db_database08.mdb"); 
S$conn->open($connstr); 

?> 


(2) 执行 查询 并 将 日 期 转换 为 “xxxx 年 xx 月 xx 日 ”格式 ， 代 码 如 下 : 


<?php 

include("conn.php"): // 包 含 数据 库 连 接 文件 

S$rs=new com("adodb.recordset"): 

S$rs->open("select bookname.syassort.price.number,format(analysetime,' yyyymmdd') as newdate from tb_booksort".$conn.3.1): 
| Srs->bof){ 


<tr> 
<td height="25" colspan="8" bgcolor="#FFFFFF"><div align="center"> 图 书 名 称 </div></td> 
<ltr> 


while(!$rs->eof) { 
> 
<t> 


<td height="25" bgcolor="#FFFFFF"><div align="center"><?php S$E-Srs->ficlds(booknamej:echo 
iconv("gbk"."utf-8",$f->value):?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php $f=$rs->fields(price):echo iconv("gbk","utf-8",$f->value):?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php $f=$rs->fields(number):echo 
iconv("gbk", "utf-8".$f->value):?></div></td> 
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<td height="25" bgcolor="#FFFFFF"><div align="center"><?php $f-$rs->ficlds(syassort):echo 
iconv("gbk","utf-8",$f->value):?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php $f=$rs->ficlds(newdate):echo 
iconv("gbk","utf-8",$f->value);?></div></td> 
<ltr> 


</tr> 
</table> 
php 

} 
> 


国 秘笈 心 法 


心 法 领悟 432: format0 函 数 的 局 限 性 。 
由 于 format0 函 数 只 适用 于 Access 数据 库 ， 在 正常 程序 开发 过 程 中 ， 只 有 在 使 用 Access 数据 库 的 程序 中 可 
以 偶尔 看 见 此 函数 。 


着 | 
实例 433 趣味 指数 : 寅 食 食 全 | 
图 实例 说 明 


本 实例 通过 使 用 字符 串 函 数 从 学 生 信息 表 中 查找 03 级 全 体 学 生 的 信息 。 运 行 本 实例 ， 如 图 8.105 所 示 ， 单 
击 图 中 的 “查询 ”按钮 即 可 将 03 级 所 有 学 生 的 信息 显示 出 来 。 


阴 日 科技 


03101 小 于 
0312102 EE 
0313303 小 王 
012104 4 
L2101 小 刘 
Oa12106 小 清 


8.105 在 查询 中 使 用 字符 串 函 数 查询 03 级 学 生 信息 


力 关键 技术 


获取 某 字 段 中 指定 位 置 的 字符 串 ， 可 以 通过 函数 mid0 实 现 ， 该 函数 的 使 用 格式 如 下 : 

mid(str,start [length]) 

参数 说 明 : 

str: 必要 参数 ， 字 符 串 表达 式 ， 从 中 返回 字符 ， 如 果 string 包含 null， 将 返回 null。 

start: 必要 参数 ,为 long 型， 是 指 string 中 被 获取 出 部 分 的 字符 位 置 。 如 果 start 超过 string 的 字符 数 , midO 
函数 将 返回 零 长 度 字 符 。 

length: 可 选 参数 ， 为 variant long， 指 要 返回 的 字符 数 ， 如 果 省 略 或 length 超过 文本 的 字符 数 〈 包 括 start 
处 的 字符 ) ， 将 返回 字符 串 从 start 到 尾 端的 所 有 字符 。 
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力 设计 过 程 


(1) 建立 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 
<?php 
$conn=new com("adodb.connection"); /连接 Access 数据 库 
Sconnstr="provider=microsoft.jet.oledb.4.0:data source=".realpath("./data/db_database08.mdb"); 
S$conn->open($connstr); 
?> 


(2) 查询 03 级 全 体 学 生 的 信息 ， 并 显示 查询 结果 ， 代 码 如 下 : 
<2php 


include("conn.php"); // 包 含 数据 库 连接 文件 

Srs=new com("adodb.recordset"); 

Srs->open("select sno,sname,sclass,sscore,ssubject from score where mid(sno.1.2)=03".$conn,3,1); 
if($rs->eofl| $rs->bof) { 

> 


<t> 
<td height="25" colspan="8" bgcolor="#FFFFFF"><div align="center"></div></td> 
</ltr> 
php 
}elsef 
while(!Srs->eof){ 
> 
<tr> 


<td height="25" background="images/head.JPG"><div align="center"><?php $f=$rs->ficlds("sno"); echo iconv("gbk","utf-8", 
Sf->value);9></div></td> 
<td height="25" background="images/head.JPG"><div align="center"><?php $f=$rs->ficlds("sname"); echo iconv("gbk", "utf-8", 
Sf->value);?></div></td> 
<td height="25" background="images/head.JPG"><div align="center"><?php $f=$rs->ficlds("sclass"): echo iconv("gbk","utf-8", 
Sf->value); ?></div></td> 
<td height="25" background="images/head. JPG"><div align="center"><?php $f=$rs->ficlds("ssubject"); echo iconv("gbk","utf-8", 
Sf->value);9></div></td> 
<td height="25" background="images/head. JPG"><div align="center"><?php $f=$rs->ficlds("sscore"); echo iconv("gbk","utf-8", 
Sf->value);9></div></td> 
</tr> 
<?php 
S$rs->movenext; 


</tr> 
</table> 
<?php 
} 


2> 


图 秘笈 心 法 


心 法 领悟 433: mid0 函 数 的 局 限 性 。 
mid0 函 数 在 Access 数据 库 中 得 到 了 广泛 的 应 用 , 但 是 该 函数 同 transform 一 样 , 都 只 适用 于 Access 数据 库 。 


实例 434 


四 实例 说 明 


本 实例 将 根据 员工 的 出 生日 期 自动 计算 员工 年 龄 并 显示 结果 。 运 行 本 实例 ， 如 图 8.106 所 示 ， 单 击 图 中 的 
“查询 ”按钮 ， 即 可 将 所 有 员工 信息 显示 出 来 。 
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明日 科技 


图 8.106 查询 员工 生日 信息 


力 关键 技术 
使 用 DateDift0 函 数 可 返回 两 个 指定 日 期 的 时 间 间 隔 ， 该 函数 的 语法 格式 如 下 : 


DateDifftinterval .datel, date2 [firstday of week [firstweek of year]]) 

参数 说 明 : 

interval: 必 选 参数 ， 字 符 串 表达 式 ， 用 来 计算 datel 和 date2 的 时 间 间 隔 。 

datal,date2: 必 选 参数 ， 用 于 指定 具体 日 期 。 

firstday of week: 可 选 参数 ， 指 定 一 年 第 一 周 的 常数 ， 如 果 未 指定 ， 则 以 包含 1 月 1 日 的 星期 为 第 一 周 。 


力 设计 过 程 
(1) 建立 conn php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 


<2phy 
Se com("adodb.connection"); // 连 接 数 据 库 
S$connstr="provider=microsoftjet.oledb.4.0:data source=".realpath("./data/db_database08.mdb"); 
S$conn->open($connstr); 
?> 
(2) 执行 查询 并 通过 函数 DateDifftO 计 算 所 有 员工 的 年 龄 ， 显 示 查 询 结果 ， 代 码 如 下 ; 
<?php 
include("conn.php"); // 包 含 数据 库 连 接 文件 
S$rs=new com("adodb.recordset"); 
/查询 结果 


Srs->open("select ygid,name.sex,address,DateDiff('yyyy’,birthday:DATE()) as age from tb_worker",Sconn,3,1); 
这 Srs->eofl $rs->bof) { 
> 


<tr> 

<td height="25" colspan="8" bgcolor="#FFFFFF"><div align="center"></div></td> 
</t> 
<?php 

jslse{ 

while(!$rs->eof){ 

?> 
<tr> 


<td height="25" background="../089/images/head.JPG"><div align="center"><?php $f=S$rs->fields("ygid"): echo 
iconv('gbk’,'utf-8',$f->value):?></div></td> 
<td height="25" background="../089/images/head.JPG"><div align="center"><?php $f=S$rs->fields("name"):; echo 
iconv('gbk','utf-8',$f->value):?></div></td> 
<td height="25" background="../089/images/head.JPG"><div align="center"><?php $f-$rs->ficlds("sex"): echo 
iconv(‘gbk','utf-8',$f->value): ?></div></td> 
<td height="25" background—"../089/images/head.JPG"><div align="center"><?php $f-$rs->ficlds("age"): echo 
iconv(‘gbk','utf-8',$f->value):?></div></td> 
<td height="25" background="../089/images/head.JPG"><div align="center"><?php $f=S$rs->fields("address"); echo 
iconv('gbk','utf-8',$f->value):?></div></td> 
<t> 
<?php 
S$rs->movenext: 


} 
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心 法 领悟 434: 对 DateDiff0 函 数 的 参数 解析 。 
DateDiff0) 函 数 中 的 参数 interval 用 来 计算 datel 和 date2 的 时 间 间 隔 。 此 参数 可 以 选择 一 些 设 定数 ,例如 yyyy、 
q、m、y 等 ， 分 别 表示 年 、 季 、 月 、 一 年 的 日 数 等 。 


| 

可 高 级 | 

实例 435 起 听 指 才 页 克 友 od 
图 实例 说 明 


本 实例 将 统计 员工 信息 表 中 员工 工资 大 于 1500 元 的 员工 职称 。 运 行 本 实例 ， 如 图 8.107 所 示 ， 单 击 图 中 的 
“查询 ”按钮 ， 即 可 将 所 有 工资 在 1500 元 以 上 的 员工 职称 显示 出 来 。 


8.107 查询 工资 大 于 1500 元 的 员工 职称 


图 关键 技术 


having 语句 的 语法 格式 如 下 : 
[having <search_condition>] 


参数 <search_condition> 指 定 组 或 聚合 应 满足 的 条 件 。 当 having 与 group by all 一 起 使 用 时 ，having 子 句 可 蔡 
代 all。 

having search_condition 语句 与 group by 语句 合用 ， 可 用 来 设置 一 些 被 含 入 查询 结果 的 “组 别 ” 所 要 符合 的 
条 件 。having 语句 可 以 包含 多 个 查询 所 需要 的 条 件 ， 并 且 这 些 过 滤 条 件 之 间 通 过 and 或 or 运算 符 相 连接 ， 同 时 
也 可 以 利用 not 运算 符 来 道 转 一 个 布尔 表达 式 。 
看 设计 过 程 

创建 脚本 文件 index.php, 开启 MySQL 服务 并 连接 MySQL 数据 库 ， 当 单 击 “ 查 询 ” 按 钮 时 ， 显 示 如 图 8.107 
所 示 的 内 容 ， 核 心 代码 如 下 : 

<?php 


$conn = mysql_connect("localhost"."root"."111") or die ("Connect MySQL False"): // 连 接 MySQL 

mysql_select_db("db_database08",$conn): /连接 MySQL 数据 库 

mysql_query("SET NAMES utf8"): /设置 编码 格式 

if($_GET[id] = "1"){ // 当 地 址 栏 参 数 等 于 1 时 
Srs = mysql_query("select + from tb_demo091 group by id having sal>1500") or die ("false"); // 返 回 结果 集 


> 
<table width="580px"><tr><td background="pic/head.JPG"> 员 工 ID</td><td background="pic/head.JPG"> 员 工 姓名 </td><td 
background="pic/head.JPG"> 员 工 职称 </td><td background="pic/head.JPG"> 员 工 工资 <ltd></tr> 


hp 
while($rst = mysql fetch row(Srs)){ /循环 输出 结果 
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> 
<tr><td background="pic/head JPG"><?php echo Srst[0]:?></td><td background="pic/head JPG"><?php echo $rst[1]:?></td><td 
background="pic/head JPG"><?php echo $rst[2]:?></td><td background="pic /head.JPG"><?php echo $rst[3]:?></td></tr> 
php 
} 
} 
?> 


国 秘笈 心 ; 


心 法 领悟 435: 如 何 使 用 having 子 句 。 
having 子 句 用 于 指定 组 或 聚合 的 搜索 条 件 .having 通 常 与 group by 子 句 一 起 使 用 ,如 果 SQL 语句 中 不 含 group 
by 子 句 ，having 子 句 的 行为 与 where 子 句 一 样 。 


8.8 数据 的 导入 和 导出 


在 对 网 站 的 数据 库 进行 管理 的 过 程 中 ， 经 常 需要 将 数据 库 中 的 数据 从 一 个 数据 库 导 入 到 另 一 个 数据 库 中 ， 
有 时 还 涉及 不 同 数据 库 之 间 的 导入 和 导出 。 


高 级 | 
实例 436 趣味 指数 : 请 塘 庚 庚 | 
实例 说 明 


使 用 PHP 语言 开发 与 数据 库 操作 有 关 的 程序 时 ， 最 佳 搭档 是 MySQL 数据 库 ， 要 在 MySQL 数据 库 中 实现 导 
入 和 导出 的 操作 方法 有 很 多 ， 这 里 介绍 一 种 通过 程序 来 实现 导入 和 导出 的 方法 。 运 行 本 实例 ， 效 果 如 图 8.108 
所 示 。 


8.108 数据 自身 的 导入 和 导出 


力 关键 技术 


实现 数据 导入 和 导出 的 原理 是 : 首先 从 A 数据 库 中 读 取 要 导出 的 数据 ， 并 将 该 数据 输出 到 页 面 中 。 然 后 与 
B 数据 库 建立 连接 ， 将 从 A 数据 库 中 读 取 到 的 数据 存储 到 B 数据 库 指定 的 表 中 。 


图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 MySQL 数据 库 ， 设 置 页 面 编码 格式 为 UTF-8， 其 代码 如 下 : 
php 
$conn = mysql_connect("localhost". "root"."111") or die ("Connect MySQL False"): /连接 数据 库 服务 器 
mysql_select_db("db_database08",$conn) or die ("Connect Database False"): /连接 数据 库 
mysql_query("SET NAMES UTFS8"): /设置 数据 库 编码 格式 
> 
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(2) 新 建 index.php 文件 ， 包 含 数 据 库 连 接 文件 ， 通 过 数据 库 的 查询 、 输 出 和 添加 函数 完成 数据 在 不 同 数 
据 表 之 间 的 导入 、 导 出 操作 ， 其 关键 代码 如 下 : 
hp 


<?pl 
这 $ POST[click] — "1"){ / 单 击 按钮 
include("conn .php"); // 包 含 数据 库 文件 
Srs = mysql_query("select * from tb_demo092_in"); // 返 回 结 果 集 
Snum = mysql_num rows($rs); // 返 回 数据 条 数 
Snums = mysql_num fields($rs); // 返 回 字段 数 
if($num != 0){ // 如 果 数 据 条 数 不 等 于 0 条 
echo "导出 数据 如 下 表 所 示 "; 
echo "<table><tr>"; 
for($a = 0;$a < Snums:$at+){ /循环 
echo "<td width= 90px' background='pic/head. JPG>".mysql field_name($rs,$a)."</td>"; 
echo "</tr></table>"; 
while($rst = mysql_fetch_row($rs){ /循环 输出 数据 
echo "<table><tr>"; 


for($a = 0;$a < Snums:$a++){ 
echo "<td width='90px’ background='pic/head.JPG>".$rst[$a]."</td>"; 


} 
echo "</tr></table>"; 
} 
<a href="index.php?id=2"> 向 表 2 导入 数据 </a> // 超 链接 
<?php 
Jelse{ 
echo "<script>alert( 数 据 表 1 为 空 .请 操作 数据 表 2):</script>"， /JavaScript 提示 
} 
i } 
if($_GET[id] = "1"){ // 如 果 地 址 栏 id 等 于 1 
include("conn.php"); // 包 含 数据 库 连 接 文件 
Srs = mysql_query("select * from tb_demo092_out"); // 返 回 结果 集 
while($rst = mysql_fetch_row($rs)){ /循环 输出 
// 插 入 操作 
mysql_query("insert into tb_demo092_in(id,name,code.dept.sal,date)value('$rst[0]','S$rst[1].,'Srst[2]','$rst[3]''$rst[4],'$rst[S])"); 
} 
mysql_query('truncate table tb_demo092_out); // 清 空 数据 库 
echo "<script>alert(' 导 入 数据 成 功 "):location.href='index.php'</script>"; /JavaScript 提示 
可 
国 秘笈 心 法 


心 法 领悟 436: 不 同 数据 库 之 间 的 导入 和 导出 。 
本 实例 实现 的 是 在 同一 数据 库 中 不 同 数据 表 之 间 的 导入 和 导出 操作 ， 而 不 同 数据 库 之 间 的 导入 和 导出 原理 
与 本 实例 是 相同 的 ， 只 是 需要 编写 两 个 连接 数据 库 的 方法 ， 分 别 对 不 同 数据 库 中 的 数据 表 进 行 操作 。 


国 实例 说 明 


在 数据 库 管 理 过 程 中 ， 不 仅 需要 实现 MySQL 数据 库 自 身 的 导入 、 导 出 操作 ， 有 时 还 需要 将 其 他 数据 库 中 
的 数据 导入 到 MySQL 数据 库 中 。 运 行 本 实例 ， 将 SQL Server 数据 库 中 的 数据 导入 到 MySQL 数据 库 中 ， 如 
图 8.109 和 图 8.110 所 示 。 


| 
| 
| 
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8.109 导出 SQL Server 数据 


图 关键 技术 


本 实例 需要 连接 SQL Server 数据 库 和 MySQL 数据 库 ， 然 后 从 SQL Server 数据 库 的 指定 表 中 读 取 数据 ， 将 
数据 添加 到 MySQL 数据 库 的 指定 表 中 。 连 接 MySQL 和 SQL Server 数据 库 的 方法 如 下 : 


<php 
$conn = mssql_connect("PC-201006101638","sa"."") or die ("Connect MsSQL False"); ” // 连 接 SQL Server 


图 8.110 创建 MySQL 数据 表 名 称 


mssql_select_db("db_database0008",$conn) or die ("Connect Database False"): // 连 接 数据 库 
$con = mysql_connect("localhost", "root","111") or die ("Connect MySQL False"); /| 连接 MySQL 
mysql_select_db("db_database08",$con) or die ("Connect Database False"); /| 连接 数据 库 


mysql_query("SET NAMES UTFS"): 
> 


图 设计 过 程 
(1) 新 建 conn.php 文件 ， 分 别 连接 MySQL 和 SQL Server 数据 库 。 
(2) 新 建 index.php 文件 。 首 先 通过 mssql 函数 库 操作 SQL Server 数据 库 ， 查 询 并 输出 SQL Server 指定 数 


据 表 中 的 数据 ， 然 后 在 MySQL 数据 库 中 创建 一 个 指定 的 数据 表 ， 并 且 将 从 SQL Server 数据 库 中 读 取 的 数据 添 
加 到 MySQL 数据 库 的 数据 表 中 ， 其 代码 如 下 : 


?php 

if($_GET[id] = "1){ // 单 击 按钮 
include('conn.php’): // 包 含 数据 库 连接 文件 
$ms = mssql_query("select * from tb_demo093"); /查询 数据 库 操作 

?> 


<table width="580px"><tr><td>SQL Server 数据 信息 </td></tr><tr><td background="pic/head.JPG"><?php echo 
mssql_ficld_name($ms.0):?></td><td background="pic/head.JPG"><?php echo mssql_field_name($ms.1):?></td><td 
background="pic/head.JPG"><?php echo mssql_field_name($ms.2):?></td><td background="pic/head.JPG"><?php echo 
mssql_ficld_name($ms,3):?></td><td background="pic/head.JPG"><?php echo mssql field_name($ms.4):?></td><td 
background="pic/head.JPG"><?php echo mssql field name($ms.5):?></td></tr> 
?php 

while($mms = mssql_fetch_array(Sms)){ /循环 输出 结果 


?> 


<tr><td background="pic/head.JPG"><?php echo $mms[id]:?></td><td background="pic /head.JPG"><?php echo 
iconv("gbk", "utf-8", $mms[name]):?></td><td background="pic/head.JPG"><?php echo $mms[code]:?></td><td background="pic /head.JPG"><?php 
echo $mms[dept]:?></td><td background="pic/head.JPG"><?php echo $mms[sal]:?></td><td background="pic/head. JPG"><?php echo 

iconv("gbk", "utf-8",$mms[date]):?></td></tr> 


<?php 
) 

?> 

if($_GET[id] = "2"){ // 单 击 按钮 
include("conn.php"): // 包 含 数据 库 连 接 页 
Srs =mysql_query("select * from tb_demo093"): // 查 询 数据 库 操作 


?> 


<table class="tee" width="580px"><tr><td class="th">MySQL 数据 信息 </td></tr><tr><td background="pic/head.JPG"><?php echo "员工 
ID\W"'.mysql_field_name($rs.0):?></td><td background="pic/head.JPG"><?php echo "员工 姓名 \\".mysql_field_name($rs.1):?></td><td 
background="pic/head.JPG"><?php echo "员工 编号 \".mysql_field_name($rs.2):?></td><td background="pic/head.JPG"><?php echo "所 属 部 门 
Wmysql_ficld_name($rs.3):?></td><td background="pic/head.JPG"><?php echo "员工 工资 \".mysq]_field_name($rs.4):?></td><td 
background="pic/head.JPG"><?php echo "当前 时 间 \W".mysql_field_name($rs,5);?></td></tr> 


<?php 
while(Srst = mysql_fetch_amay(Srs)){ 


// 循 环 输出 结果 


S85 
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ey background="pic/head.JPG"><?php echo Srstfid]:?></td><td background="pic/head JPG"><?php echo Srst[name]:?></td><td 
background="pic/head JPG"><?php echo $rst[code]:?></td><td background="pic /head.JPG"><?php echo $rst[dept]:?></td><td 
background="pic/head.JPG"><?php echo Srst[sal]:?></td><td background="pic /head.JPG"><?php echo Srst[date]:?></td></tr> 
<2php 

} 
} 
?> 


图 秘笈 心 ; 


心 法 领悟 437: 连接 SQL Server 数据 库 的 注意 事项 。 

PHP 在 默认 情况 下 ， 是 不 能 连接 SQL Server 数据 库 的 。 为 了 能 够 连接 SQL Server 数据 库 ， 必 须 修 改 php.ini 
文件 的 设置 (在 更 改 文件 前 需要 去 除 该 文件 的 只 读 属性 ) ， 将 :extension=php_mssql.dll 语句 前 的 分 号 删除 ， 然 后 
重新 启动 Apache 服务 器 即 可 。 


MySQL 数据 库 中 高 级 
实例 
sn | ee 
国 实例 说 明 

在 对 数据 库 进 行 管理 的 过 程 中 ， 不 同 数据 库 之 间 的 数据 转换 是 很 麻烦 的 ， 本 实例 利用 ADO 连接 Access 数 
据 库 ， 将 Access 数据 库 中 的 数据 导入 MySQL 数据 库 中 ， 运 行 结果 如 图 8.111 所 示 。 
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图 8.111 显示 导入 到 MySQL 中 的 数据 


图 关键 技术 


本 实例 重点 讲解 如 何 将 PHP 与 Access 数据 库 建立 连接 ， 以 及 如 何 使 用 PHP 语句 从 Access 数据 库 中 读 取 数 
据 ， 并 将 数据 添加 到 MySQL 数据库 中 。 

这 里 使 用 微软 的 ADODB 数据 库 驱 动 实现 PHP 与 Access 数据 库 的 连接 。PHP 是 通过 预定 义 类 com 来 使 用 
ADO 方法 操纵 Access 数据 库 的 ， 该 类 的 详细 说 明 如 下 : 

ET 

参数 说 明 : 

module_name: 被 请 求 组 件 的 名 字 或 class-id。 

server_name: DCOM 服务 器 的 名 字 。 

codepage: 指定 用 于 将 PHP 字符 串 转换 成 UNICODE 字符 串 的 代码 页 , 反之 亦 然 。 该 参数 的 取 值 有 CP_ACP、 
CP MACCP, CP OEMCP、, CP_SYMBOL, CP THREAD ACP、 CP UTF7 和 CP UTF8. 


PHP 利用 com 类 并 使 用 ADO 方法 访问 数据 库 的 代码 如 下 : 
ns com("adodb.connection"): 
Sconnstr="provider=microsoftjet.oledb.4.0;data source=".realpath("./data/score.-mdb"): 
Seonn>open(Seonnst); 
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图 设计 过 程 
(1) 新 建 conn.php 文件 ， 完 成 与 Access 数据 库 和 MySQL 数据 库 的 连接 ， 其 代码 如 下 : 
< 
a com("adodb.connection"): 
Sconnstr—"provider=microsoft.jet.oledb.4.0;data source=" realpath("Access database/db_demo094.mdb"): 
$conn->open($connstr):; 
S$rs=new com("adodb.recordset"); 
$con = mysql._connect("localhost","root","111") or die ("Connect MySQL False"); 
mysql_select_db("db_database08",$con) or die ("Connect Database False"): 
mysql_query("SET NAMES UTF8"): 
?> 


(2) 新 建 ndex.php 文件 ， 首 先 查询 Access 数据 库 ， 完 成 Access 数据 库 中 数据 的 循环 输出 ， 其 代码 如 下 : 


<?php 

if($_GET[id] = "1"){ /| 单 击 按钮 
include("conn.php"); // 包 含 数据 库 连 接 文件 
Srs->open("select * from tb_demo094",$conn); // 返 回 结果 集 
if($rs->eof]| $rs->bof) {}else{ 

> 

Access 数据 信息 

php 

while(!$rs->eof){ /| 循环 输出 结果 
?> 
<tr> 


<td><?php $=$rs->ficlds(id):echo iconv("gbk", "utf-8",$f->value):?></td><td><?php $f=$rs->fields(name);echo iconv("gbk", "utf-8",$f->value);?></td> 
<td><?php $=$rs->ficlds(dept);echo iconv("gbk","utf-8",$f->value);?></td><td><?php $f=$rs->fields(sal);echo iconv("gbk","utf-8",$f->value);?></td> 
<td><?php $f=$rs->fields(date):echo iconv("gbk"."utf-8",$f->value):?></td> 


</t> 
Iphp 
Srs->movenext; 
} 
1 
> 
<form action="" method="post"> 
<input type="text" name="te" value=" 创 建 导入 MySQL 数据 表 名 称 " onfocus="this.value="" class="one" /> 
<input type="submit" name="sub" valuc="&nbsp:" class="two" /> 
</form> 
<2php 
} 
?> 
(3) 将 Access 数据 库 中 的 数据 通过 SQL 语句 插入 到 MySQL 数据 库 中 ， 并 且 循环 输出 MySQL 数据 库 中 
的 数据 ， 其 代码 如 下 : 
if($_GET[id] = "2"){ // 单 击 按钮 
include("conn.php"); // 包 含 数据 库 连 接 页 
Srs = mysql_query("select * from tb_demo094"):; // 返 回 结果 集 
?> 
<table width="580px"> 
<t> 


<td class="th">MySQL 数据 信息 </td></tr> 
<tr><td background="pic/head.JPG">id</td> 
<td background="pic/head.JPG">name</td> 
<td background="pic/head.JPG">dept</td> 
<td background="pic/head.JPG">sal</td> 
<td background="pic/head.JPG">date</td> 
<ltr> 
<?php 
while($rst = mysql_fetch_array(Srs)){ // 循 环 输出 结果 
?> 
<t> 
<td background="pic/head.JPG"><?php echo Srst[id]:?></td> 
<td background="pic/head. JPG"><?php echo $rst[name]:?></td> 
<td background="pic/head.JPG"><?php echo Srst[dept]:?></td> 
<td background="pic/head.JPG"><?php echo S$rst[sal]:?></td> 
<td background="pic/head.JPG"><?php echo $rst[date]:?></td> 
<ltr> 
<?php 
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} 


> 


心 法 领悟 438: ActiveX Data Objects (ADO) 。 

ActiveX Data Objects (ADO) 是 Microsoft 开放 数据 库 应 用 程序 的 数据 库 访问 技术 ， 它 被 设计 用 来 同 新 的 数 
据 访 问 层 OLE DB Provider 一 起 协同 工作 ， 提 供 通 用 数据 访问 (Universal Date Access) 。OLE DB 是 一 个 低层 
的 数据 访问 接口 ， 用 它 可 以 访问 各 种 数据 源 ， 包 括 传统 的 关系 型 数据 库 、 电 子 邮件 系统 及 自 定义 的 商业 对 象 。 
ADO 技术 大 大 简化 了 OLE DB 的 操作 ， 因 为 ADO 封装 OLE DB 程序 中 使 用 的 大 量 COM 接口 ， 所 以 ADO 是 
一 种 高 层 的 访问 技术 。 


8.9 MySQL 数据 库 的 备份 和 恢复 


MySQL 数据 库 的 功能 是 非常 强大 的 ， 为 确保 数据 库 中 数据 的 安全 ， 对 数据 定期 进行 备份 是 很 重要 的 。 


| 


图 实例 说 明 


在 命令 行 模式 下 可 以 实现 创建 、 修 改 、 删 除数 据 库 、 数 据 表 及 数据 表 中 的 数据 信息 的 操作 。 同 样 也 可 以 在 
命令 模式 下 对 数据 库 进 行 备份 ， 可 通过 mysqldump 命令 将 整个 数据 库 备份 到 指定 文件 夹 下 的 文本 文件 中 ， 其 运 
行 效果 如 图 8.112 和 图 8.113 所 示 。 


区 mh_astshese000 - 记事 本 
Er EE 


~ MSAL dam 10-13 Distrid 5-1.M1, For Win32 (C1332) 


(Cost ocainost 


NRACTER_SET_RESULI CTER SET RESULTS 2/; 
RE tet FnNNECTION «/; 


ern SE eon, UNTOUF_CHECKS=@UNT NUE_CHECKS , UNTOUE_CHECKS=0 «/; 
SET QOLD_FORELGH KEY_CHECKS-QQFORE IGH_KEY_CHECKS , 
anton PE >/ 
iLD_SQL_HDDE-easQL_HOpE， 


eon DE mo! A )_UALUE_ON_ZERO® #/; 
和 /=?40111 SET B0LD_SQL_NDTES-GGSQL_HNOTES，SQL_NOTES-9 */3 加 | 
图 8.112 cmd 命令 备份 数据 库 图 8.113 文本 文件 备份 数据 库 内 容 
图 关键 技术 


在 命令 模式 下 实现 对 数据 库 的 备份 ， 应 用 的 是 mysqldump 命令 ， 其 语法 如 下 : 
mysqldump -uroot -pl111 db_database08 > D:\db_databaseO08.txt: 
图 设计 过 程 
执行 备份 操作 的 步骤 如 下 : 
(1) 选择 “开始 ”菜单 中 的 “运行 ”命令 。 
(2) 在 弹出 对 话 框 的 文本 框 中 输入 cmd， 单 击 “ 确 定 ” 按 钮 ， 进 入 命令 模式 。 
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(3) 在 命令 模式 中 直接 输入 mysqldump -uroot -p111 db _database08 > db_database08.txt， 然 后 按 Enter 键 即 可 。 
其 中 ，-uroot 中 的 root 是 用 户 名 ， 而 -p111 中 的 111 是 数据 库 密码 ; db _database08 是 数据 库 名 称 ; 
D:vdb database08.txt 是 数据 库 备 份 的 存储 位 置 。 


心 法 领悟 439: 手动 设置 环境 变量 。 

在 命令 模式 下 操作 MySQL 数据 库 ， 最 好 先 对 计算 机 的 环境 变量 进行 设置 。 右 击 “ 我 的 电脑 ”， 从 弹出 的 
快捷 菜单 中 选择 “属性 ”命令 ， 在 弹出 的 对 话 框 中 选择 “高 级 ”选项 卡 ， 然 后 在 其 中 单 击 “环境 变量 ”按钮 ， 
并 在 用 户 变 量 的 文本 框 中 找到 变量 PATH 选项 并 将 其 选中 ， 单 击 “ 编 辑 ” 按 钮 ， 在 变量 PATH 的 变量 值 文本 框 
中 输入 路 径 F:xamppxamppimysql\bin (MySQL 数据 库 中 bin 文件 夹 的 安装 路 径 ) ， 然 后 单 击 “ 确 定 ”按钮 。 其 
中 添加 的 bin 文件 夹 的 路 径 根据 安装 MySQL 数据 库 的 位 置 而 定 。 


实例 440 趣味 指数 ， 宽 本 太 评 


图 实例 说 明 
备份 MySQL 数据 库 的 操作 可 以 在 命令 模式 下 实现 ， 也 可 以 通过 phpMyAdmin 图 形 化 管理 工具 来 实现 。 
phpMyAdmin 为 Web 开发 人 员 提 供 类 似 Access、SQL Server 的 图 形 化 数据 库 操作 界面 ， 通 过 该 管理 工具 可 
以 进行 绝 大 部 分 的 MySQL 操作 ， 包 括 对 数据 库 及 数据 表 的 建立 和 维护 。 
图 关键 技术 


本 实例 运用 phpMyAdmin 图 形 化 管理 工具 完成 对 数据 库 的 备份 操作 。 在 备份 数据 库 之 前 ， 首 先 选 择 需 要 备 
份 的 数据 库 ， 然 后 根据 导航 栏 的 提示 实现 数据 库 备份 即 可 。 


力 设计 过 程 
通过 phpMyAdmin 图 形 化 管理 工具 备份 数据 库 ， 既 可 以 备份 整个 数据 库 ， 也 可 以 备份 数据 库 中 的 一 个 表 。 


(1) 打开 phpMyAdmin 图 形 化 管理 工具 , 在 地 址 栏 输入 http:/127.0.0.1/phpmyadmin/， 进 入 如 图 8.114 所 示 
的 页 面 中 。 
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图 8.114 phpMyAdmin 图 形 化 管理 工具 的 页 面 
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(2) 在 界面 左 侧 的 下 拉 列 表 框 中 选择 要 备份 的 数据 库 ， 显 示 其 包含 的 所 有 表 的 信息 ， 如 图 8.115 所 示 。 
(3) 单 击 图 8.115 “导出 ”按钮 ， 对 db_database08 要 提 库 过 全 各 的 5 3 天 的 江面 知 交 8.116 所 示 。 
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图 8.115 ”数据库 db_database08 的 操作 界面 图 8.116 db_database08 数据 库 导出 的 界面 


(4) 在 图 8.116 所 示 的 界面 中 选择 数据 的 格式 为 SQL， 选 中 “另存 为 文件 ” 复 选 框 ， 单 击 “ 执 行 ”按钮 ， 
在 弹出 的 对 话 框 中 单 击 “ 保 存 ” 按 钮 ， 将 数据 库 的 文件 保存 到 指定 的 文件 夹 中 。 


国 秘笈 心 法 


心 法 领悟 440: phpMyAdmin 备份 数据 库 和 数据 表 。 
phpMyAdmin 备份 整个 数据 库 与 备份 单个 数据 表 的 操作 方法 相同 。 


°° | 
高 级 : 
实 斧 
实例 441 趣味 指数 : 妇女 太太 
国 实例 说 明 
前 面 介绍 的 实例 是 通过 输入 命令 或 者 使 用 工具 来 备份 数据 库 ， 但 通过 以 上 备份 方式 存储 数据 的 备份 文件 是 
不 安全 的 ， 当 打开 备份 文件 时 就 可 以 看 到 该 数据 库 中 的 内 容 。 这 里 将 介绍 一 种 更 简单 且 安全 性 更 高 的 备份 方式 ， 
即 通过 手动 方式 直接 备份 MySQL 数据 库 安装 路 径 下 data 文件 夹 中 的 数据 库 文件 。 


通过 这 种 方式 备份 出 的 文件 不 是 文本 文件 ， 不 能 用 文本 编辑 器 打开 ， 只 有 在 MySQL 服务 启动 后 ， 通 过 命 
令 模式 或 者 管理 工具 才能 看 到 数据 库 中 的 内 容 。 


力 关键 技术 


通过 手动 方式 备份 数据 库 ， 就 是 将 备份 的 数据 文件 复制 到 指定 的 位 置 。 切 记 ， 在 MySQL 服务 器 未 停止 的 
情况 下 ， 不 能 删除 或 者 剪 切 data 文件 夹 下 的 数据 库 文件 。 


图 设计 过 程 


(1) 找到 MySQL 数据 库 的 安装 路 径 ， 在 MySQL 根 目录 下 找到 data 文件 夹 。 本 书 中 data 文件 夹 的 存储 位 
置 是 F:\xampp\xamppvmysqlvdata。 

(2) 打开 data 文件 夹 ， 选 择 要 备份 的 数据 库 名 称 。 

(3) 将 要 备份 的 数据 库 文件 夹 复 制 到 指定 的 位 置 下 。 
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心 法 领悟 441: 处 理 不 同 版 本 数据 库 的 差异 。 
由 于 使 用 的 MySQL 数据 库 的 版 本 不 同 , 在 进行 备份 时 , 有 的 版 本 需要 停止 MySQL 服务 后 才 可 以 备份 文件 ， 
以 XAMPP 为 例 ， 启 动 和 停止 MySQL 服务 的 方法 如 图 8.117 所 示 。 
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实例 442 


力 实例 说 明 


本 实例 将 介绍 通过 命令 模式 恢复 数据 库 的 方法 ， 它 针对 的 是 实例 439 中 通过 命令 模式 备份 数据 库 的 操作 。 


图 关键 技术 


通过 命令 模式 恢复 数据 库 使 用 的 是 mysql -uroot -p111 db_database08 < D:\db_database08.txt 命令 ， 其 中 -u 
后 的 root 代表 用 户 名 ，-p 后 的 root 代表 密码 ，db_database08 代表 数据 库 名 称 〈 或 表 名 ) ，“<” 号 后 面 的 
D:vdb_database08.tst 是 数据 库 备份 文件 存储 的 位 置 。 
在 命令 模式 下 恢复 整个 数据 库 文 件 ， 命 令 如 下 : 
CiDocuments and Setting\Administrator > mysql -uroot -p111db_database08 < D:\db_databaseO8.txt; 
图 设计 过 程 

恢复 数据 库 的 操作 步骤 如 下 : 

(1) 选择 “开始 ”菜单 中 的 “运行 ”命令 。 

(2) 在 弹出 的 对 话 框 中 输入 cmd 命令 ， 单 击 “ 确 定 ”按钮 ， 进 入 命令 模式 。 

(3) 在 命令 模式 中 直接 输入 mysql -uroot -p111 db_database08 < D:\db_database08.txt， 然 后 按 Enter 键 ， 即 
可 实现 数据 库 的 恢复 ， 运 行 效果 如 图 8.118 所 示 。 


和 秘笈 心 法 


心 法 领悟 442: 命令 行 下 备份 和 恢复 数据 库 的 缺点 。 
由 于 此 种 备份 和 恢复 数据 库 的 方法 都 是 要 依托 客户 机 硬盘 上 的 文本 文件 ， 而 文本 文件 是 以 明文 的 方式 保存 
数据 库 信息 的 ， 所 以 安全 性 较 低 。 


实例 443 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


高 级 
趣味 指数 : 请 禄 请 庚 | 


力 实例 说 明 
本 实例 介绍 通过 phpMyAdmin 图 形 化 管理 工具 恢复 数据 库 的 方法 , 它 针对 的 是 实例 440 中 通过 phpMyAdmin 
图 形 化 管理 工具 备份 数据 库 的 操作 。 


力 关键 技术 

本 实例 的 操作 方法 十 分 简单 ， 相 关 技 术 已 经 在 实例 440 中 介绍 过 了 ， 这 里 不 再 效 述 。 

在 执行 恢复 数据 库 的 操作 时 ， 首 先 必须 在 phpMyAdmin 图 形 化 管理 工具 中 选中 一 个 数据 库 ， 然 后 再 执行 导 
入 文件 的 操作 。 
力 设计 过 程 


通过 phpMyAdmin 图 形 化 管理 工具 恢复 数据 库 的 步骤 如 下 : 


(1 
公 
询 窗 口中 


) 打开 phpMyAdmin 图 形 化 管理 工具 ， 在 该 界面 左 侧 窗口 的 下 拉 列 表 框 中 选择 要 恢复 的 数据 库 。 
) 在 phpMyAdmin 图 形 化 管理 工具 操作 界面 的 左 侧 窗口 中 单 击 SQL 查询 窗口 按钮 进入 查询 界面 ， 在 查 
h 单 击 “ 导 入 ”按钮 ， 根 据 提示 浏览 文本 文件 所 在 的 位 置 ， 找 到 该 文件 后 ， 单 击 “ 执 行 ”按钮 即 可 。 


图 秘笈 心 法 
心 法 领悟 443: phpMyAdmin 图 形 化 管理 工具 的 版 本 差异 。 
phpMyAdmin 图 形 化 管理 工具 因 版 本 不 同 ， 实 现 导 入 文本 文件 的 方法 也 不 相同 ， 但 实现 步骤 大 致 相同 。 
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实例 444 


力 实例 说 明 


本 实例 介绍 一 种 最 简单 的 数据 库 恢复 方式 ， 也 是 最 常用 的 MySQL 数据 库 恢复 方式 ， 即 通过 手动 恢复 数 
据 库 。 


图 关键 技术 


通过 该 方法 恢复 数据 库 是 针对 手动 备份 数据 库 进行 操作 的 ， 只 需 将 手动 备份 的 数据 库 文件 复制 到 MySQL 
数据 库 安装 路 径 下 的 data 文件 夹 下 即 可 。 

复制 完成 后 ， 最 好 重新 启动 MySQL 数据 库 ， 确 保 数据 库 文件 被 正确 地 读 取 。 另 外 ， 如 果 数 据 库 文件 具有 
只 读 属性 ， 那 么 一 定 要 将 只 读 属性 去 掉 ， 否 则 将 只 能 浏览 数据 库 中 的 数据 ， 不 能 对 数据 库 进行 添加 、 修 改 或 者 
删除 的 操作 。 


力 设计 过 程 
通过 手动 方式 恢复 整个 数据 库 文件 的 操作 步骤 如 下 : 


(1) 找到 通过 手动 方式 备份 的 数据 库 文件 。 
(2) 将 数据 库 文件 复制 到 MySQL 数据库 安 装 路 径 下 的 data 文件 夹 中 , 这 样 即 可 完成 通过 手动 方式 恢复 数据 库 。 


秘笈 心 ; 


心 法 领悟 444: 处 理 不 同 版 本 数据 库 的 差异 。 

由 于 使 用 的 MySQL 数据 库 的 版 本 不 同 ， 在 进行 备份 时 有 的 版 本 需要 停止 MySQL 服务 后 才 可 以 备份 文件 ， 
这 里 再 介绍 一 种 启动 和 停止 MySQL 服务 的 方法 。 

(1) 选择 “开始 ”/“ 设 置 ”/“ 控 制 面板 ”命令 。 

(2) 双击 “管理 工具 ”， 打 开 管 理工 具 操作 界面 。 

(3) 双击 “服务 ”选项 图 标 ， 进 入 服务 操作 界面 。 

(4) 找到 MySQL 服务 选项 ， 右 击 ， 在 弹出 的 快捷 菜单 中 对 MySQL 服务 进行 “启动 ”或 “停止 ”操作 。 


8.10 phpMyAdmin 图 形 化 管理 工具 


phpMyAdmin 是 众多 MySQL 图 形 化 管理 工具 中 应 用 最 广泛 的 一 种 , 是 基于 PHP 语言 编写 的 , 该 工具 是 B/S 
结构 的 、 基 于 Web 跨 平 台 的 管理 程序 ， 并 且 支 持 简体 中 文 ， 可 以 在 官方 网 站 免费 下 载 。 


实例 445 


趣味 指数 : 伍 食 食 食 


国 实例 说 明 


图 形 化 管理 工具 phpMyAdmin 的 出 现 使 MySQL 数据 库 具有 了 如 Access 和 SQL Server 数据 库 一 样 简单 而 明 
了 的 操作 界面 ， 使 程序 员 在 设计 MySQL 数据 库 时 变 得 简单 。phpMyAdmin 几乎 可 以 实现 操作 数据 库 的 所 有 功 


PHP 开发 实例 大 全 (基础 卷 ) 
能 。 本 实例 将 演示 如 何 通过 phpMyAdmin 修改 MySQL 用 户 密码 。 
图 关键 技术 


通过 phpMyAdmin 修改 MySQL 用 户 密码 的 方法 有 两 种 : 
(1) 直接 通过 phpMyAdmin 的 界面 进行 更 改 。 
(2) 通过 修改 phpMyAdmin 文件 夹 下 的 配置 文件 config php 实现 更 改 。 


图 设计 过 程 
1. 通过 phpMyAdmin 的 界面 进行 密码 修改 


(1) 登录 到 phpMyAdmin 图 形 化 工具 页 面 ， 单 击 “ 修 改 密码 ”按钮 ， 如 图 8.119 所 示 。 
(2) 根据 页 面 提示 输入 新 密码 和 确认 密码 ， 如 图 8.120 所 示 。 
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图 8.119 ” phpMyAdmin 图 形 化 界面 图 8.120 ”修改 MySQL 数据 库 密码 
(3) 单 击 “ 执 行 ” 按 钮 ， 修 改 MySQL 数据 库 密 码 ， 如 图 8.121 所 示 。 
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TT 辐 | 
图 8.121 完成 密码 修改 


2. 通过 修改 配置 文件 进行 密码 修改 
(1) 将 下 载 的 phppMyAdmin-x.zip 文件 解压 到 Apache 默认 的 根 目 录 下 ， 解 压 后 的 名 称 是 phpMyAdmin- 
2.x.x.x， 其 中 的 2.x.xx 是 版 本 号 ， 为 方便 使 用 ， 可 以 将 其 重新 命名 为 phpMyAdmin。 
(2) 打开 phpMyAdmin 文件 夹 ， 找 到 配置 文件 config.php， 然 后 使 用 记事 本 或 其 他 编辑 工具 打开 该 文件 ， 
找到 该 文件 中 的 以 下 内 容 进行 配置 : 
S$cfg[PmaAbsoluteUri] = http://127.0.0.1/phpMyAdmin ': 
以 上 用 于 设置 phpMyAdmin 的 URL， 例 如 http://127.0.0.1/phpMyAdmin。 
Scfe['blowfish_secret] = root: 
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在 上 述 语句 中 更 改 用 户 密码 ， 例 如 root。 


$cfe[Servers][Sil[controluser] = root: 
Scfe['Servers'][$il['controlpass’] = root': 
Scfe['Servers'][$i['user] = root 
Scfe['Servers'][$i['password’] = root': 
(3) 完成 配置 后 保存 该 文件 。 


心 法 领悟 445: phpMyAdmin 图 形 化 管理 工具 的 优点 。 
phpMyAdmin 图 形 化 管理 工具 几乎 是 所 有 的 PHP+MySQL 用 户 必 备 的 利器 之 一 ， 其 优点 是 : 


(1) 程序 本 身 由 PHP 语言 编写 并 且 是 开源 的 ， 对 于 PHP 编程 爱好 者 来 说 非常 适合 。 
(2》 江 天 昌 然 免费 但 荔 能 并 不 欠 陕 ; 它 可 以 很 完 半 地 完成 对 MySQL 数据库 的 各 种 操作 


数据 库 、 数 据 表 编码 高 级 | 
趣味 指数 ， hoboiodl 


实例 446 


力 实例 说 明 


将 页 面 、 程 序 文件 、 数 据 库 与 数据 表 设 置 为 统一 的 编码 格式 可 以 避免 程 序 运行 时 出 现 乱 码 。 一 般 情况 下 ， 
设置 页 面 的 编码 格式 由 HIML 中 的 <meta> 标 签 实现 , 设置 程序 文件 的 编码 格式 由 mysql_query0 实 现 , 设置 数据 
库 与 数据 表 的 编码 格式 通过 phpMyAdmin 实现 。 


力 关键 技术 


本 实例 的 操作 方法 十 分 简单 ， 在 创建 数据 库 名 称 时 ， 在 “整理 ”下 拉 列 表 框 中 选择 需要 设置 的 编码 格式 ; 
在 创建 数据 表 时 ， 同 样 将 数据 字段 设置 为 统一 的 编码 格式 。 


力 设计 过 程 


(1) 登录 到 phpMyAdmin 图 形 化 工具 页 面 ， 创 建 数据 库 名 称 ， 选 择 编码 格式 ， 如 图 8.122 所 示 。 
(2) 创建 数据 表 ， 定 义 数据 表 字段 并 设置 编码 格式 ， 如 图 8.123 所 示 。 
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心 法 领悟 446: 设置 统一 的 编码 格式 。 
在 创建 数据 表 字 段 时 ， 一 般 将 字符 类 型 的 数据 字段 设置 为 统一 的 编码 格式 ， 对 于 数值 型 数据 字段 ， 可 以 不 
进行 编码 格式 的 设置 。 


高 级 
实例 447 趣味 指数 : 8 克 友 区 
图 实例 说 明 


phpMyAdmin 可 以 实现 在 cmd 命令 行 下 对 数据 库 的 操作 , 而 且 操作 更 简单 、 直观。 本 实例 通过 phpMyAdmin 
实现 对 数据 库 的 创建 和 删除 操作 。 


图 关键 技术 

切记 ， 在 创建 数据 库 时 ， 一 定 要 设置 数据 库 的 编码 格式 。 注 意 ， 一 旦 执行 删除 操作 ， 数 据 库 将 不 能 再 恢复 。 
图 设计 过 程 

(1) 登录 到 phpMyAdmin 主页 ， 根 据 提示 编写 新 建 数据 库 的 名 称 并 设置 数据 库 的 编码 格式 ， 如 图 8.124 
所 示 。 

(2) 单 击 “ 创 建 ” 按 钮 ， 创 建 数据 库 并 自动 选择 创建 的 数据 库 为 当前 数据 库 。 


(3) 如 果 数 据 库 已 经 没有 任何 作用 ， 可 以 通过 phpMyAdmin 删除 数据 库 。 选 择 想 要 删除 的 数据 库 ， 单 击 导 
航 栏 中 的 “删除 ”按钮 ， 根 据 提示 决定 是 否 删除 数据 库 ， 如 图 8.125 所 示 。 
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国 秘笈 心 法 


心 法 领悟 447: phpMyAdmin 图 形 化 工具 与 cmd 命令 下 操作 数据 库 。 
通过 phpMyAdmin 图 形 化 工具 与 在 cmd 命令 下 操作 数据 库 没 有 任何 区 别 ， 只 是 phpMyAdmin 的 设计 者 对 
MySQL 数据 库 的 相关 指令 进行 了 封装 ， 使 一 些 对 MySQL 数据 库 不 了 解 的 用 户 也 可 以 操作 数据 库 。 
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力 实例 说 明 


对 数据 表 的 操作 一 般 包括 创建 和 删除 ， 本 实例 介绍 应 用 phpMyAdmin 图 形 化 工具 实现 对 数据 表 的 创建 和 删 
除 操作 。 


图 关键 技术 


想 要 创建 数据 表 ， 首 先 要 创建 数据 库 ， 当 数据 库 创建 完成 时 自动 选择 已 经 创建 好 的 数据 库 ， 根 据 提示 编写 
数据 表 名 称 并 创建 数据 表 。 而 删除 数据 表 时 ， 需 要 选择 想 要 删除 的 表 ， 然 后 单 击 “ 删 除 ” 按 钮 即 可 完成 。 


图 设计 过 程 
(1) 登录 到 phpMyAdmin 界面 ， 创 建 数据 库 ， 选 择 数据 库 编码 格式 ， 单 击 “ 创 建 ”按钮 ， 根 据 提示 编写 数 
据 表 名 称 ， 并 填写 想 要 创建 数据 表 的 字段 数目 ， 如 图 8.126 所 示 。 


(2) 进入 编写 数据 库 字 段 页， 建立 数据 表 结构 ， 填 写字 段 信息 ， 其 中 包括 字段 名 称 、 字 段 类 型 、 字 段 长 度 、 
是 否 允 许 为 空 等 ， 如 图 8.127 所 示 
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(3) 单 击 “ 保 存 ” 按 钮 ， 完 成 数据 表 的 创建 。 
(4) 删除 数据 表 时 ， 首 先 选择 要 删除 的 数据 表 名 称 并 进入 数据 表 操 作 界 面 ， 单 击 导航 栏 中 的 “删除 ”按钮 ， 
根据 提示 删除 数据 表 ， 如 图 8.128 所 示 。 


力 秘笈 心 ; 
心 法 领悟 448: 使 用 phpMyAdmin 图 形 化 工具 创建 数据 表 的 注意 事项 。 


在 创建 数据 表 结 构 时 也 要 对 数据 表 字 段 进 行 编码 格式 设置 ， 而 且 必须 为 数据 表 指 定 主键 、 设 置 索引 ， 和 否则 
会 出 现 如 图 8.129 所 示 的 提示 内 容 。 
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力 实例 说 明 


对 MySQL 数据 库 中 数据 的 操作 包括 插入 、 删 除 、 修 改 和 查询 等 。 本 实例 将 介绍 如 何 通过 phpMyAdmin 图 
形 化 管理 工具 完成 上 述 的 操作 。 


图 关键 技术 


phpMyAdmin 图 形 化 管理 工具 操作 数据 的 关键 点 如 下 : 

查询 数据 信息 : 进入 表 名 为 tb_demo〈 以 也 _demo 为 例 ) 的 数据 表 界面 ， 单 击 导航 栏 中 的 “浏览 ”按钮 。 
插入 数据 信息 : 单 击 导航 栏 中 的 “插入 ”按钮 ， 根 据 提示 插入 信息 。 

回 ”删除 数据 信息 单 击 删除 字段 的 X 按钮， 删除 一 行 数据 。 

回 ”修改 数据 信息 ， 单 击 修改 字段 的 成 按钮 ， 修 改 一 个 或 多 个 字段 数据 。 


看 设计 过 程 
(1) 查询 数据 信息 。 首 先进 入 tb_demo 数据 表 ， 默 认 情 况 下 直接 显示 数据 表 的 信息 。 如 果 刚 刚 进行 完 其 他 
130 所 示 。 
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图 8.130 查询 数据 信息 
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(2) 插入 数据 信息 。 单 击 导航 栏 中 的 “插入 ”按钮 ， 进 入 插入 信息 界面 ， 完 成 数据 的 添加 后 单 击 “ 执 行 ” 
按钮 ， 实 现 插入 数据 ， 如 图 8.131 所 示 。 

(3) 删除 数据 信息 。 首 先 返回 到 数据 浏览 页 ， 如 果 要 删除 单条 数据 信息 ， 直 接 单 击 该 条 数据 的 删除 按钮 ; 
如 果 要 删除 多 条 数据 信息 ， 可 以 选中 数据 信息 前 端的 复 选 框 ， 然后 单 击 数据 表 信息 下 端的 “选中 项 删除 ”按钮 ; 
如 果 要 删除 数据 表 中 的 所 有 信息 ， 可 以 单 击 导航 栏 中 的 “清空 ”按钮 ， 实 现 删除 所 有 数据 信息 ， 如 图 8.132 
所 示 。 


CG 和 @ 列 乡 单 条 数据 
io 
| 


Ri, er P 


ped mhr0) [ea [CE | 


[7 Frwy EE 司 全 水 并 有 在。 行 捕 生生 姐 
| [可 演 
记 寺 | Ea a oR Rn Sh cree VE ly 
Se | EF 一 = TM | 
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(4) 修改 数据 信息 。 修 改 数据 信息 与 删除 数据 信息 类 似 , 可 以 分 为 修改 单条 数据 信息 和 修改 多 条 数据 信息 。 
修改 单条 数据 信息 时 直接 单 击 该 条 数据 的 修改 按钮 进入 修改 页 面 ， 即 可 实现 修改 ， 修 改 多 条 数据 信息 时 ， 首 先 
要 选中 复 选 框 ， 然 后 单 击 “ 选 中 项 修改 ”按钮 ， al 汪 la 和 图 8.134 所 示 。 
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心 法 领悟 449: 在 phpMyAdmin 图 形 化 界面 工具 中 修改 操作 与 删除 操作 的 区 别 。 

如 果 在 修改 多 条 数据 时 ， 误 选中 不 需 更 改 的 数据 信息 前 的 复 选 框 ， 进 入 修改 页 面 后 可 以 不 对 此 条 数据 做 任 
何 修改 ， 此 条 数据 信息 不 会 有 任何 变化 。 如 果 在 删除 多 条 数据 时 ， 误 选中 了 不 需 删除 的 数据 信息 前 的 复 选 框 ， 
则 单 击 “ 执 行 ”按钮 后 信息 会 被 删除 。 
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9.1 PHP 的 MySQLi 扩展 库 


在 PHP 5.0 以 后 的 版 本 中 ,为 适应 MySQL 数据 库 的 新 特性 重新 编写 了 MySQLi 扩展 库 。MySQLi 扩展 库 同 
时 提供 了 面向 过 程 和 面向 对 象 的 两 种 调用 接口 ， 本 节 将 通过 具体 实例 讲解 如 何 使 用 MySQLi 扩展 库 对 MySQL 
数据 库 进行 操作 。 


A 连接 MySQL 数据 库 中 级 | 


力 实例 说 明 


本 实例 主要 实现 使 用 MySQLi 扩展 库 的 面向 对 象 的 方式 建立 与 MySQL 数据 库 的 连接 。 运 行 本 实例 ， 如 
9.1 所 示 ， 在 页 面 中 打印 出 数据 库 连 接 成 功 的 提示 信息 ， 从 而 说 明 已 经 成 功 连接 上 MySQL 数据 库 。 


9 www.mrboed.com 上 EE 4 
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9.1 数据 库 连接 成 功 


图 关键 技术 


使 用 MySQLi 扩展 库 面向 对 象 的 方法 建立 与 MySQL 数据 库 的 连接 ， 主 要 是 使 用 mysqli 类 实现 的 ， 该 类 的 
构造 方法 的 语法 格式 如 下 : 


class mysqli{ 
_construct ( [string host [, string usemame [, string passwd [, string dbname [, int port]]]]] ) 


} 
mysqli 类 的 构造 方法 的 参数 说 明 如 表 9.1 所 示 。 


表 9.1 mysqli 类 的 构造 方法 的 参数 说 明 


passwd MySQL 数据 库 服 务 器 密码 

dbname | 要 连接 的 MySQL 数据 库 的 名 称 

Port MySQL 数据 库 服 务 器 端口 号 ， 默 认为 3306 
图 设计 过 程 


(1) 创建 数据 库 db_database09。 在 MySQL 中 创建 数据 库 可 以 通过 SQL 语句 或 phpMyAdmin 图 形 化 管理 
工具 实现 ， 本 实例 将 采用 命令 方式 创建 MySQL 数据 库 ， 其 创建 代码 如 下 : 


CREATE DATABASE db _database09 ; 


(2) 使 用 函数 parse_ini file0 解 析 配 置 文件 config.ini 以 获得 数据 库 连 接 参 数 ,然后 使 用 new 关 键 字 对 mysqli 
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类 进行 实例 化 , 最 后 使 用 函数 mysqli connect_ermo0 判 断 是 否 成 功 连接 上 了 MySQL 数据 库 , 实现 该 过 程 的 代码 


如 下 : 
ty{ 
Sconfig = parse_ini file(realpath(dimame( FILE ).'/config/config ini]): /| 解析 config ini 文件 
Smysqli = new mysqli($config['host], $config[usemame], Sconfig[password]. Sconfig[dbname]): /对 mysqli 类 进行 实例 化 
imysqli_conneet_ ermoO){ // 济 断 是 否 成 功 连接 上 MySQL 数据 库 
了 hrow new Exception(<br/> 数 据 库 连接 错误 ! ，); /如果 连接 错误 ， 则 抛 出 异常 
lse{ 
echo 数据 库 连 接 成 功 !'; // 打 印 连 接 成 功 的 提示 
. 
jcatch (Exception $e){ /捕获 异常 
echo $e->getMessage(): /打印 异常 信息 


< 注意 : 使 用 MySQLi 扩展 库 完成 对 MySQL 数据 库 的 操作 后 , 还 应 该 通过 调用 MySQLi 类 实例 对 象 的 close0 
方法 释放 资源 。 


心 法 领悟 450: 使 用 MySQLi 扩展 库 的 面向 过 程 的 方式 连接 MySQL 数据 库 。 
使 用 MySQLi 扩展 库 不 仅 可 以 采用 面向 对 象 的 方式 建立 与 MySQL 数据 库 的 连接 ， 为 了 适应 不 同 开发 习惯 
用 户 的 需求 ， 同 时 提供 了 面向 过 程 的 方式 对 MySQL 数据 库 进行 管理 。 使 用 MySQLi 面向 过 程 的 方式 建立 与 


MySQL 数据 库 的 连接 是 通过 mysqli_connect0 函 数 实现 的 ， 该 函数 的 语法 格式 如 下 : 
mysqli_connect( [string host [, string username [, string passwd [, string dbname [, int port]]]]] ) 
该 函数 参数 的 使 用 方式 与 mysqli 类 的 构造 方法 相同 ， 这 里 不 再 袭 述 。 


力 实例 说 明 


在 Web 项 目 开发 过 程 中 ,经 常 需要 对 大 量 数据 信息 进行 查询 操作 ， 本 实例 主要 介绍 如 何 使 用 MySQLi 扩展 
技术 实现 商品 信息 的 检索 。 运 行 本 实例 ， 如 图 9.2 所 示 ， 在 图 中 文本 框 中 输入 要 查找 的 商品 名 称 ， 单 击 “ 查 找 ” 
按钮 ， 如 果 该 商品 存在 则 显示 该 商品 的 所 有 信息 ， 否 则 提示 没有 查找 到 该 商品 。 


VOODOO 网 


实现 数据 库 信息 的 检索 初级 
趣味 指数 : 请 请 庚 | 


商品 信息 管理 系统 
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图 9.2 商品 信息 查询 


国 关键 技术 


在 MySQLi 扩展 库 面向 对 象 的 编程 方式 中 ， 可 以 使 用 mysqli 类 中 的 query0 方 法 执行 查询 操作 ,该 方法 的 语 
法 格式 如 下 : 

ixed query ( string query [, int resultmode] ) 

参数 说 明 : 

query: 要 执行 的 查询 语句 。 
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resultmode: 用 于 指定 结果 模式 ， 这 里 可 以 取 MYSQLI STORE RESULT 和 MYSQLI USE RESULT 两 个 
值 , 使 用 MYSQLI USE_ RESULT 时 在 执行 下 一 条 查询 前 必须 调用 mysqli_result 的 free0 方 法 或 close0 方 法 释放 
查询 结果 对 象 ， 否 则 查询 失败 。 如 果 执 行 查询 返回 结果 数据 量 较 大 ， 一 般 使 用 MYSQLI USE RESULT。 


图 设计 过 程 


(1) 建立 如 图 9.2 所 示 的 商品 信息 管理 页 面 ， 在 页 面 中 建立 按 商 品名 称 查 询 商 品 信息 的 表单 ， 该 页 面 的 创 


建 代码 请 详 见 本 书 光盘 ， 同 时 建立 conn.php 文件 实现 与 数据 库 的 连接 ， 该 文件 的 代码 如 下 : 
$conn=new mysqli("localhost","root","111"."db_database09"); /建立 与 数据 库 的 连接 
S$conn->query("set names utf8"); // 设 置 数据 库 字 符 集 


(2) 当 用 户 单 击 表 单 中 的 “查找 ”按钮 后 , 将 通过 如 下 代码 按照 用 户 在 表单 中 录入 的 关键 字 进行 匹配 查询 。 
在 下 述 代 码 中 ， 首 先 判 断 用 户 是 否 提交 了 表单 ， 如 果 是 ， 则 首先 使 用 include_once 语句 包含 conn.php 文件 ， 然 
后 使 用 mysqli 类 实例 后 的 对 象 调用 query0 方 法 执行 查询 ， 并 使 用 执行 查询 后 的 返回 对 象 调用 fetch_array0 方 法 
获得 查询 结果 集 ， 如 果 结 果 集 不 为 空 则 在 页 面 中 打印 结果 集 ， 反 之 打印 未 查询 到 结果 的 提示 信息 。 


<?php 

if($_POST[submit]!="") // 判 断 用 户 是 否 提交 了 表单 
include_once("conn.php"); // 包 含 conn.php 文件 
Sname=$_POST[name]; // 获 得 提交 关键 字 
$sql=$conn->query("select * from tb_goods where name like '%".$name."%"); // 执 行 查询 
Sinfo=$sql->fetch_array(MYSQLI ASSOC): // 获 得 查询 结果 集 
isinfo 一 NULIJ{ 


echo "<div align=center> 没 有 查找 到 该 商品 !</div>"; 
jelsef 


> 
<!-- 省 略 代码 ， 请 参见 本 书 附带 光盘 -> 
dof // 通 过 循环 显现 查询 结果 
?> 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo S$infofnamel:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[price]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo S$info[shuliang]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo S$info[addtime]:?></div></td> 


心 法 领悟 451: 获得 MySQLi 扩展 库 的 结果 集 。 

使 用 mysqli 类 中 的 query0 方 法 所 返回 的 对 象 来 调用 fetch_array0 方 法 ， 可 以 获得 查询 结果 集 ， 该 方法 的 语 
法 格式 如 下 : 

feteh_array ( [int resulttype] ) 

fetch_array() 方 法 中 包含 一 个 可 省 参数 resulttype， 该 参数 用 于 指定 返回 结果 的 类 型 ， 其 参数 取 值 及 说 明 
如 下 : 

MYSQLI_ASSOC: 指定 返回 结果 集 为 关联 数组 。 

MYSQLI NUM: 指定 结果 集 为 索引 数组 。 

MYSQLI_ BOTH: 指定 结果 集 既 包含 关联 数组 又 包含 索引 数组 。 
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实例 
力 实例 说 明 
在 开源 项 目 开 发 中 ，MySQL 数据 库 被 广泛 应 用 。 这 不 但 因为 MySQL 数据 库 是 完全 免费 的 ， 而 且 MySQL 
数据 库 和 PHP 一样 都 是 完全 跨 平台 的 。 但 在 实际 项 目 开 发 过 程 中 ，PHP 与 MySQL 数据 库 产生 连接 错误 是 不 可 
避免 的 ， 本 实例 将 讲解 如 何 实现 尽 可 能 早 地 发 现 这 种 连接 错误 。 运行 本 实例 ， 分 别 如 图 9.3 和 图 9.4 所 示 。 图 中 


所 示 错 误 都 是 当 连 接 数 据 库 服务 器 时 用 户 密码 输入 错误 所 致 ， 其 中 图 9.3 在 页 面 中 打印 出 上 述 错误 的 信息 ， 
9.4 外 
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图 9.3 显示 错误 信息 图 9.4 显示 错误 号 


图 关键 技术 


在 MySQLi 扩展 技术 中 ， 可 以 使 用 两 种 方式 获得 数据 库 连接 错误 报告 ， 一 种 是 直接 获取 错误 的 名 称 ， 另 一 
种 是 获取 连接 错误 所 代表 的 错误 号 。 

直接 获取 错误 的 名 称 可 以 使 用 函数 mysqli_connect_error0 实 现 ， 该 函数 的 语法 格式 如 下 : 

string mysqli_connect_error(mysqli link) 

该 函数 将 返回 一 个 错误 消息 ， 该 消息 对 应 于 使 用 MySQLi 扩展 技术 连接 MySQL 数据 库 时 所 产生 的 错误 。 

获取 连接 MySQL 数据 库 时 产生 的 错误 号 可 以 使 用 函数 mysqli_connect_errno() 实 现 ， 该 函数 的 说 明 如 下 : 

int mysqli_connect_errno() 

如 果 在 连接 MySQL 数据 库 服 务 器 时 出 现 了 错误 ， 就 会 产生 一 个 该 错误 对 应 的 消息 数字 ， 利 用 该 函数 就 可 
以 获取 该 数字 。 下 面 为 连接 MySQL 数据 库 时 可 能 发 生 错 误 的 错误 号 及 错误 内 容 : 

1045: Access denied for user ' 用 户 名 '@' 用 户 密码 '(user password:YES) 

上 述 错误 代表 用 户 密码 输入 错误 。 

2005: Unknown MySQL server host "MySQL 数据 库 服务 器 名 (11004) 

上 述 错误 代表 MySQL 数据 库 服务 器 名 称 输入 错误 。 


2013: Loset connection to MySQL server during query 


上 述 错 误 代表 在 执行 查询 时 失去 了 与 MySQL 数据 库 的 连接 。 
痊 提示 : 在 项 目 开发 中 ， 可 以 通过 try/catch 语句 捕获 通过 MySQLi 扩展 库 连 接 MySQL 数据 库 所 产生 的 异常 。 


力 设计 过 程 
(1) 建立 index.php 文件 ， 用 于 建立 PHP 与 MySQL 数据 库 的 连接 ， 并 输入 错误 的 用 户 密码 ， 代 码 如 下 : 
S$conn=mysqli_connect("localhost"."root". "root1"): // 建 立 与 MySQL 数据 库 的 连接 
echo mysqli_connect_errnoO); /打印 错误 号 
(2) 建立 index_1.php 文件 ,用 于 建立 PHP 与 MySQL 数据 库 的 连接 ， 并 输入 错误 的 用 户 密码 ， 代 码 如 下 : 
$conn=mysqli_connect("localhost"."root". "root1"): // 建 立 与 MySQL 数据 库 的 连接 
echo mysqli_connect_error(); /打印 错误 提示 
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(3) 分 别 执行 index.php 文件 和 index_1.php 文件 查看 结果 ， 如 图 9.3 和 图 9.4 所 示 。 


心 法 领悟 432: 使 用 函数 mysqli error0 和 mysqli ermo0 获 得 最 后 一 次 出 错 的 错误 信息 和 错误 号 。 

本 实例 使 用 函数 mysqli connect_error0 和 mysqli connect_errmo() 来 获得 连接 数据 库 时 的 错误 信息 和 错误 号 ， 
那么 如 何 获得 MySQLi 扩展 库 在 操作 MySQL 数据 库 过 程 中 的 所 有 错误 信息 和 错误 号 呢 ? 这 里 可 以 使 用 函数 
mysqli_error() 和 mysqli ermo0 实 现 ， 其 中 函数 mysqli_error0 用 于 返回 操作 MySQL 数据 库 时 最 后 一 次 的 错误 信 
息 ， 其 语法 格式 如 下 : 

string mysqli_error ( mysqli link ) 

参数 link 为 函数 mysqli_connect0 成 功 连 接 MySQL 数据 库 的 连接 句柄 。 

mysqli_ermo0 用 于 返回 操作 MySQL 数据 库 时 最 后 一 次 的 错误 号 ， 其 语法 格式 如 下 : 


int mysqli_ermo (mysqli link ) 


同样 ， 参 数 link 为 函数 mysqli_connect0 成 功 连接 MySQL 数据 库 的 连接 句柄 。 


实例 453 趣味 指数 ， 请 博 请 | 
图 实例 说 明 


一 个 成 型 的 项 目 会 包含 很 多 数据 表 ， 并 且 表 之 间 可 能 存在 相互 关联 ， 本 实例 将 讲解 如 何 使 用 MySQLi 扩展 
库 执行 多 表 之 间 的 关联 查询 。 运 行 本 实例 ， 如 图 9.5 所 示 ， 在 页 面 中 打印 出 学 生 的 学 号 、 姓 名 和 主要 科目 的 成 


绩 信息 。 
0312316 这 星星 四 25 % 
0312317 置 个 全 % 7» 
0312318 李 个 本 76 $6 如 
9.5 学 生成 绩 列表 
力 关键 技术 


实现 本 实例 的 关键 技术 是 如 何 通 过 主键 实现 多 表 之 间 的 连接 查询 ， 下 面 是 本 实例 实现 多 表 查 询 的 代码 : 


$sql=$conn->query("select * from tb_student tb_score where tb_student.id=tb_score.sid"); 

实现 多 表 之 间 的 查询 应 在 from 子 句 后 列 出 所 有 的 表 名 ， 并 且 表 名 之 间 用 逗号 进行 分 隔 。 同 时 应 在 where 关 
键 字 中 指明 多 表 之 间 的 连接 条 件 ， 例 如 本 实例 中 的 tb_student.id=tb_score.sid， 表 示 学 生 表 和 成 绩 表 之 间 通 过 学 
生 表 的 id 字段 和 成 绩 表 的 sid 字段 进行 连接 。 


看 设计 过 程 
(1) 建立 conn.php 文件 实现 与 MySQL 数据 库 之 间 的 连接 ， 代 码 如 下 : 
Sconn=new mysqli("localhost","root"."111","db_database09"); /建立 与 MySQL 数据 库 的 连接 
$conn->query("set names utf8"); // 设 置 字符 编码 格式 


(2) 建立 index.php 文件 用 于 实现 多 表 之 间 的 查询 ， 如 果 学 生 表 和 成 绩 表 中 有 满足 条 件 的 记录 则 显示 这 些 
记录 ， 和 否则 提示 没有 相关 信息 ， 代 码 如 下 : 


<2php 
include_once("conn.php"): // 包 含 conn php 文件 
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$sql=$conn->query("select * from tb_studenttb_score where tb_student id=tb_score.sid"): /| 执行 关联 查询 
Sinfo=$sql->fetch_array(MYSQLI ASSOC): // 获 得 查询 结果 集 
if($info—NULD){ // 未 查 到 结果 ， 将 给 出 提示 
echo " 暂 无 学 生 信 息 ": 
jelsef 
dof 
ry 
<t> 


<td height="20" bgcolor="#FFFFFF"><div align="center"><?php echo $info[sno]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[sname]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[yw]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $infofwy]:?></div></td> 
<td bgeolor="#FFFFFF"><div align="center"><?php echo $info[sx];?></div></td> 
<i> 
<php 
jwhile( Sinfo=$sql->fetch_array(MYSQLIL ASSOC)); // 通 过 循环 打印 成 绩 信息 


> 


心 法 领悟 453: 使 用 隐 式 连接 查询 实现 多 表 之 间 的 关联 查询 。 
实现 本 实例 所 采用 的 多 表 之 间 的 关联 查询 称 为 显示 关联 查询 ， 查 询 语句 如 下 : 


select * from tb_student,tb_score where tb_student.id=tb_score.sid 
除了 使 用 上 述 显示 关联 查询 外 ， 还 可 以 使 用 内 连接 查询 方式 实现 多 表 之 间 的 隐 式 关联 查询 ， 如 本 实例 的 多 
表 连 接 查询 可 以 更 改 成 如 下 形式 : 


select * from tb_student inner join tb_score on tb_student.id=tb_score.sid 
上 述 内 连接 查询 中 ， 使 用 inner join 子 句 指定 要 连接 的 表 名 ， 使 用 on 子 句 指定 两 个 表 的 连接 条 件 ， 如 果 还 
有 其 他 查询 条 件 ， 可 以 指定 where 子 句 。 


[ED 说 明 : 为 了 规范 数据 库 查询 技术 ， 隐 式 查询 方式 将 成 为 多 表 连 接 查询 的 主流 方式 。 


技术 实现 内 存 的 回收 初级 | 


力 实例 说 明 


为 了 有 效 利用 服务 器 的 内 存 空 间 ， 在 获取 较 大 结果 集 时 ， 一 旦 结束 操作 则 有 必要 回收 集合 所 需要 的 内 存 ， 
由 于 MySQLi 技术 可 以 采用 面向 对 象 和 面向 过 程 两 种 编程 方式 ， 所 以 与 之 对 应 的 内 存 回收 方式 也 有 两 种 ， 笔 者 
将 通过 本 实例 讲解 内 存 回收 机 制 在 项 目 开发 过 程 中 的 意义 和 使 用 方法 。 运 行 本 实例 ， 如 图 9.6 所 示 ， 图 中 为 某 
班级 学 生 主要 科目 成 绩 的 列表 ， 并 在 显示 完 该 班 成 绩 后 对 内 存 进行 了 回收 。 


0312315 EI 加 54 
1915 3 加 5 | 四 
ED 商人 全 加 加 
EE EE 加 回 加 


图 9.6 学 生成 绩 列表 


图 关键 技术 


PHP 为 了 迎合 不 同 开发 习惯 的 程序 员 , 在 MySQLi 扩 展 技术 中 提供 了 面向 对 象 和 面向 过 程 两 种 编程 方式 ， 
所 以 实现 内 存 回收 也 存在 与 之 对 应 的 两 种 方式 。 如 果 采 用 面向 过 程 的 编程 方式 ， 可 以 通过 如 下 函数 实现 内 存 
回收 : 
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bool mysqli_close ( object link) 
参数 link 指 mysqli_connect0 函 数 返 回 的 数据 库 连接 句柄 。 


如 果 采 用 面向 对 象 的 编程 方式 ， 可 以 通过 如 下 语句 实现 : 
Tink->close0) 


link 指 PHP 预定 义 的 mysqli 类 实例 化 后 的 对 象 。 
图 设计 过 程 


(1) 建立 conn.php 文件 ， 实 现 与 MySQL 数据 库 之 间 的 连接 。 在 conn.php 文件 中 ， 首 先 使 用 new 关键 字 
对 mysqli 类 进行 实例 化 ， 然 后 通过 实例 后 的 对 象 调用 query0 方 法 执行 查询 来 设置 数据 库 的 字符 编码 为 UTF-8 


编码 ， 其 实现 代码 如 下 : 
S$conn=new mysqli("localhost", "root","111","db_database09"); /建立 与 MySQL 数据 库 的 连接 
S$conn->query("set names utf8"); /设置 数据 库 字符 编码 


(2) 通过 do...while 循环 显示 该 班级 所 有 学 生 的 成 绩 。 实 现 该 功能 时 ， 首 先 使 用 include_once 语句 包含 
conn.php 文件 ,然后 通过 调用 query0 方 法 执行 查询 ,并 使 用 fetch_array0 方 法 获得 查询 结果 集 , 最 后 通过 do...while 
循环 在 页 面 中 打印 出 学 生 的 成 绩 信息 ， 实 现 该 过 程 的 代码 如 下 : 


<?php 
inelude_once("conn.php"); // 包 含 conn.php 文件 
$sql=$conn->query("select * from tb_student,tb_score where tb_studentid=tb_score.sid"); /执行 查询 
Sinfo=$sql->fetch_array(MYSQLI ASSOC): // 获 得 查询 结果 集 
if($info—NULL){ 

echo " 暂 无 学 生 信息 ": 
yelse{ 

dof // 通 过 循环 打印 查询 结果 


?> 
<tr> 
<td height="20" bgeolor="#FFFFFF"><div align="center"><?php ccho $info[sno]:?></div></td> 
<td bgeolor="#FFFFFF "><div align=reenter'><?php echo $info[sname]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[yw]:? 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[wy]: 
<td bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[sx]:?></div></td> 
<ir> 


ee 
> 
(3) 实现 内 存 的 回收 ， 这 里 分 别 调用 执行 query0 方 法 返回 对 象 的 close0 方 法 和 mysqli 实例 后 对 象 的 
close0 方 法 释放 资源 ， 代 码 如 下 : 


$sql->close(); 
Sconn->close(); 


国 秘笈 心 法 


心 法 领悟 454: 如 何 防止 页 面 出 现 中 文 乱码 。 

编写 PHP 程序 时 ,为 了 防止 页 面 出 现 乱 码 ,要求 PHP 
文件 编码 、 网 页 页 面 编 码 和 数据 库 编码 要 一 致 ， 如 果 采 
用 UTF-8 编码 , 则 上 述 三 项 内 容 都 要 设置 为 UTF-8 编码 ， 
否则 会 出 现 乱码 现象 ， 那 么 如 何 对 上 述 编 码 进行 设置 
呢 ? 设置 PHP 文件 编码 可 以 采用 UltraEdit、Edit Plus 和 
Zend Studio 等 编辑 器 ， 如 使 用 UltraEdit 设置 PHP 页 面 
文件 编码 时 , 可 以 在 另存 页 面 文件 时 选择 格式 为 UTF-8， 
如 图 9.7 所 示 。 

设置 网 页 的 页 面 编码 可 以 使 用 PHP 中 的 header0 函 数 
或 在 HTML 的 meta 标记 中 进行 。 如 果 页 面 完全 由 PHP 


图 9.7 使 用 UltraEdit 另存 PHP 文件 为 UTF-8 编码 格式 
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脚本 编写 ， 可 以 使 用 header0 函 数 设置 页 面 编码 ， 设 置 方法 如 下 : 


header('content-type:text/html; charset=UTF-8"); 


如 果 页 面 中 包含 规范 的 HTML 代码 ， 可 以 在 HTML 的 meta 标记 中 设置 页 面 编 码 ， 设 置 方 法 如 下 : 


<meta http-equiv="content-type" content="text/html:; charset=UTF-8" /> 


完成 对 PHP 文件 及 页 面 编码 的 设置 后 ， 还 需要 设置 数据 库 编 


码 ， 一 般 需要 进行 两 处 设置 。 在 创建 数据 表 时 要 设置 字段 的 字符 ”Fm 可 局 
编码 ， 其 设置 方法 如 图 9.8 所 示 。 a 


完成 上 述 设置 后 ， 一 般 还 需要 在 程序 中 采用 编码 方式 设置 数 
据 库 字符 集 ， 其 设置 方法 可 以 通过 SQL 语句 实现 ， 例 如 本 实例 通过 如 下 语句 设置 数据 库 字符 集 为 UTF-8。 


Sconn->query("set names utf8"); 


<4 儿 注意 : 设置 数据 库 字 符 编码 为 UTF-8 时 , 应 该 是 set names utf8 而 不 是 set names utf-8, 请 不 要 多 加 字符 “-”。 


实例 455 


力 实例 说 明 


在 本 实例 中 运用 mysqli 函数 库 中 的 函数 ,实现 用 户 登录 的 功能 , 从 中 体会 数据 库 连 接 函 数 (mysqli_connect()) 
和 操作 函数 《mysqli_query0、mysqli_fetch_row(O〉 的 应 用 。 运 行 本 实例 ， 当 输入 正确 的 用 户 名 和 密码 之 后 ， 将 
弹出 如 图 9.9 所 示 的 对 话 框 。 


9.9 用户 登录 


力 关键 技术 


在 本 实例 中 运用 mysqli_connect0 函 数 连接 数据 库 ， 运 用 mysqli_connect_error0 函 数 返 回 错误 信息 ， 运 用 
mysqli_fetch_row() 函 数 获取 查询 结果 的 记录 数 ， 判 断 登 录用 户 是 否 正确 。 
(1) mysqli connectO 函 数 建立 与 MySQL 数据库 服 务 器 的 连接 ， 其 语法 如 下 : 
bj eet iiysqli_connect([string hostname [ string seriaine [ string password [, string dbrane [, int port [, stiing seket]IIl]]) 
mysqli_connect 0 函数 的 参数 说 明 如 表 9.2 所 示 。 
表 9.2 mysqli_connect() 函 数 的 参数 说 明 
参数 说 有明 
hostname 可 选 参数 ，MySQL 数据 库 服务 器 的 地 址 
Usemame 可 选 参数 ，MySQL 数据 库 的 用 户 名 
password 可 选 参数 ，MySQL 数据 库 的 用 户 密码 
dbname | [ 选 参数 ， 要 连接 的 数据 库 名 
port | [ 选 参数 ，MySQL 数据 库 的 端口 号 


socket [ 选 参数 ， 用 于 指定 管道 端口 


| | 到 | 到 | 习 
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(2) mysqli_fetch_ row 函数 根据 所 获取 的 记录 生成 数组 ， 如 果 没有 更 多 记录 则 返回 NULL， 其 语法 如 下 : 
mixed mysqli fetch row( mysqli_result result ) 


参数 result 为 mysqli_query0 函 数 执行 查询 后 的 返回 值 。 
图 设计 过 程 


(1) 建立 conn.php 文件 ， 实 现 与 MySQL 数据 库 的 连接 。 在 conn.php 文件 中 ， 首 先 使 用 mysqli connectO 
函数 连接 db_database09 数据 库 ， 用 户 名 是 root， 密 码 为 111。 然 后 通过 mysqli_connect_error0 函 数 定义 错误 信 
息 ， 最 后 通过 mysqli query0O 函 数 设置 数据 库 的 编码 格式 ， 其 代码 如 下 : 


$conn=mysqli_connect("localhost","root"."111","db_database09": /连接 数据 库 
if (mysqli_connect errnoO) { 
printf(" 连 接 失败 : %s\n", mysqli_connect_error0);: // 返 回 错误 信息 
exit|; 
} 
ri query($conn,"set names utf8"); // 设 置 数据 库 编码 格式 


Er 新 建 index.php 文件 ， 创 建 form 表单 ， 将 用 户 登 录 的 用 户 名 和 密码 提交 到 index_ok.php 文件 处 理 。 
(3) 创建 index_ok.php 文件 ,获取 表单 提交 的 用 户 名 和 密码 ,根据 mysqli_fetch row() 函 数 的 返回 值 判断 登 
录 的 用 户 名 和 密码 是 否 正确 ， 其 代码 如 下 : 
<?php 


header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 


include("conn/conn.php"); // 包 含 数据 库 连 接 文 件 
if($_POST['user]!="" || $_POST['pass]!=""){ // 判 断 用 户 名 和 密码 是 否 正 确 
$sql=mysqli_query($conn,"select + from tb_login where username=".$_POST['user].”" and password=".$_POST['pass]."™"); 
Sinfo=mysqli_fetch_row($sql): // 获 取 查 询 结 果 
if(Sinfo==NULL){ 
echo "<script>alert(' 登 录 失 败 ! "); window location href='index.php'</script>"; 
yelse{ 


echo "<script>alert(' 登 录 成 功 ! '); window.location href="index.php';</script>"; 


?> 
国 秘笈 心 法 
心 法 领悟 455: mysqli_fetch rowO 函 数 的 应 用 。 


根据 mysqli_fetch rowO 函 数 的 返回 值 不 但 可 以 判断 是 否 存在 查询 结果 ， 如 果 与 while 语句 结合 使 用 ， 还 可 
以 输出 查询 结果 中 的 数据 。 


力 实例 说 明 


在 本 实例 中 运用 mysqli 函数 库 中 的 mysqli_real_connect() 
函数 实现 与 MySQL 数据 库 的 连接 , 从 而 实现 用 户 注 册 的 功能 ， 
并 且 介 绍 一 种 检测 SQL 语句 中 错误 的 方法 。 运行 本 实例 , 输入 
用 户 的 注册 信息 ， 如 果 用 户 输入 的 用 户 名 已 经 存在 ， 则 输出 用 
户 名 已 经 存在 的 提示 信息 ， 否 则 提示 用 户 注册 成 功 ， 其 运行 结 
果 如 图 9.10 所 示 。 


初级 | 
起 呆 指数 : 机 机 页 | 


图 9.10 用 户 注册 
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图 关键 技术 


在 本 实例 中 应 用 mysqli_real connectO 函 数 实现 与 MySQL 数据 库 的 连接 ， 其 前 提 是 必须 通过 mysqli_initO 
函数 为 其 设置 一 个 对 象 ， 否 则 无 法 应 用 mysqli_real_connect0 函 数 。 
(1) mysqli initO 函 数 为 mysqli options0 和 mysqli_real connectO 函 数 分 配 或 指派 对 象 ， 其 语法 如 下 : 
mysqli mysqli init (void ) 
(2) mysqli real connectO 函 数 建立 与 MySQL 数据 库 服务 器 的 连接 ， 其 语法 如 下 : 
bool mysqli_real conneci( mysqli link [, string host [, string usemame [ string passwd [ string dbname [, int port [, string socket [, int flags]]]I]]] ) 
mysqli real connectO 函 数 的 参数 说 明 如 表 9.3 所 示 。 


表 9.3 mysqli_real_connect() 函 数 的 参数 说 明 


参数 说 明 
link 必 选 参数 ，mysqli_connect0 或 mysqli_init0 函 数 所 返回 的 连接 标识 
host 可 选 参 数 ，MySQL 数据 库 服务 器 的 主机 名 或 他 地址 
username 可 选 参数 ，MySQL 数据 库 的 用 户 名 
passwd 可 选 参数 ，MYySQL 数据 库 某 用 户 对 应 的 密码 
dbname 可 选 参数 ， 用 于 指定 MySQL 数据 库 服务 器 中 指定 的 数据 库 名 称 
port 可 选 参数 ， 连 接 MySQL 数据 库 服务 器 所 应 用 的 端口 号 
Socket 可 选 参数 ， 用 于 指定 管道 端口 
flag 可 选 参 数 ， 用 于 设置 不 同 的 连接 选项 。 该 参数 可 设置 的 选项 请 参见 表 9.4 
表 9.4 flags 参数 可 设置 的 选项 说 明 
flags 参数 可 设置 的 选项 说 明 
MYSQLI CLIENT COMPRESS 应 用 压缩 协议 
MYSQLI CLIENT FOUND ROWS 返回 匹配 的 字段 数 ， 而 不 是 受 影 响 的 行 数 
MYSQLI CLIENT IGNORE SPACE 配置 函数 保留 字 
MYSQLI CLIENT INTERACTIVE 关闭 连接 之 前 允许 静止 交互 
MYSQLI CLIENT SSL Use SSL 应 用 加 密 套 接 字 协议 


(3) mysqli Es 次 应 用 数据 库 操作 函数 出 错时 的 错误 信息 ， 其 语法 如 下 : 


int mysqli_error(mysqli link 

参数 link 为 ydll cntiscil) 冰 流失 幼 连 按 上 MySQL 数据 库 服务 器 所 返回 的 连接 标识 。 

mysqli_errorO 函 数 非常 适合 应 用 在 程序 的 开发 过 程 中 ， 通 过 它 来 获取 程序 SQL 语句 中 出 现 的 错误 ， 可 以 使 
用 户 快速 、 准 确 地 找到 程序 中 的 错误 。 


图 设计 过 程 
(1) 建立 conn.php 文件 ， 实 现 与 MySQL 数据 库 之 间 的 连接 。 在 conn.php 文件 中 ， 首 先 应 用 mysqli_initO) 
函数 为 数据 库 的 连接 函数 mysqli real connect0 指 定 一 个 对 象 ， 然 后 应 用 mysqli_ real connect0 函数 连接 


db_database09 数据 库 ， 用 户 名 是 root， 密 码 为 111。 接 着 通过 mysqli_connect_error0 函 数 定义 错误 信息 。 最 后 通 
过 mysqli_query0 函 数 设置 数据 库 的 编码 格式 ， 其 代码 如 下 : 
php 


S$conn = mysqli_init(); // 指 定 对 象 

‘mysqli_real_connect($conn, ‘ocalhost', root' '111', 'db_database09); // 连 接 数据 库 

if(mysqli_connect_errno()) { // 判 断 是 否 连接 成 功 

printf(" 连 接 失 败 : %s\n". mysqli_connect_error0): // 返 回 错误 信息 
exit(); 
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mysqli_query($conn."set names gb2312"); 1/ 设置 数据 库 编码 格式 
(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 用 户 注册 信息 提交 到 index_ok.php 文件 进行 处 理 。 


(3) 创建 index_ok.php 文件 ， 获 取 表 单 提交 的 用 户 注册 信息 ， 首 先 判断 提交 的 用 户 名 是 否 被 占用 ， 如 果 未 
被 占用 ， 则 将 用 户 注册 信息 添加 到 tb_reg 表 中 ， 其 代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=gb2312" ); /设置 页 面 编码 
include("conn/conn.php"); // 包 含 数据 库 连 接 文件 
if($_POST['user]!="" || $_POST[pwd1]!="" ){ // 判 断 输 入 的 用 户 名 和 密码 是 否 为 空 
Scheck="select name from tb_reg where name=".$_ POST[user]."": /定义 验证 用 户 名 是 否 被 占用 的 SQL 
Sresult=mysqli_query($conn,$Scheck): // 执 行 查询 语句 
Sinfo=mysqli_fetch_row($result); // 获 取 查 询 结 果 
if($info!=NULL) 


{ 
echo "<script>alert(' 您 输入 的 用 户 名 已 经 存在 ! ): window.location href~'index.php':</script>"; 
Jelse{ 
ee 
values(".$_POST['user']."" .md5($_POST['pwd1"]).",".$_POST['email].",".$_POST['address'].")"; 
Sresult=mysqli_query(Sconn,$sql);: 


echo mysqli_error(Sconn): /返回 SQL 语句 中 的 错误 信息 
if($result){ 

echo "<script>alert(' 注 册 成 功 !"); window.location.href='index.php';</script>"; 
jelsef 


echo "<script>alert( 注 册 失败 !0; window.location.href='index.php';</script>"; 
} 
} 
} 


2> 


图 秘笈 心 法 
心 法 领悟 456: 检测 SQL 语句 中 的 错误 。 


在 mysqli 函数 库 中 ， 可 以 通过 mysqli_error0 函 数 来 检测 程序 SQL 语句 中 的 错误 ， 以 帮助 我 们 及 时 地 发 现 
SQL 语句 中 的 问题 。 


力 实例 说 明 


在 前 面 的 实例 中 介绍 了 如 何 通过 mysqli 函数 库 中 的 函 
数 实现 用 户 注册 和 登录 的 功能 ， 在 本 实例 中 将 介绍 如 何 通 
过 mysqli 函数 库 中 的 函数 完成 数据 的 浏览 操作 。 运行 本 实 
例 ， 将 循环 输出 数据 库 中 指定 数据 表 的 数据 ， 其 运行 结果 
如 图 9.11 所 示 。 


图 关键 技术 


在 本 实例 中 ， 获 取 查询 结果 中 数据 应 用 的 是 mysqli_fetch_object0 函 数 ， 并 结合 while 语句 完成 其 返回 对 象 
中 数据 的 输出 。 
mysqli_fetch_object0 函 数 返 回 一 个 由 执行 查询 后 生成 的 表 字段 组 成 的 对 象 ， 其 语法 如 下 : 


mixed mysqli_fetch_object(object result) 
参数 result 为 mysqli_query0 函 数 执行 查询 的 返回 值 。 
获取 返回 对 象 中 数据 的 格式 如 下 : 


9.11 浏览 注册 用 户 
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<?php echo $obj->name; ?> 


其 中 $obj 为 返回 的 对 象 ，name 为 字段 名 称 。 
图 设计 过 程 


(1) 建立 conn.php 文件 实现 与 MySQL 数据 库 之 间 的 连接 。 

(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 用 户 登 录 信息 提交 到 index_ok.php 文件 进行 处 理 。 

(3) 创建 index_ok.php 文件 ， 获 取 表 单 提交 的 用 户 登录 信息 ， 判 断 提交 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 
确 ， 则 将 登录 用 户 名 存储 到 SESSION 变量 中 并 跳 转 到 main php 文件 ， 其 代码 如 下 : 


<?php 

session_start(); // 初 始 化 SESSION 变量 
header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文 件 编码 格式 
include("conn/conn.php"); // 包 含 数据 库 连接 文件 


if($_POST['user]!="" | $_POST['pass']!="){ 
$sql=mysqli query($conn,"select + from tb login where usemame=".$ POST['user']." and password=".$ POST['pass"].""): 
Sinfo=mysqli_fetch_row($sql): 
这 Sinfo 一 NULLJ{ 
echo "<script>alert(' 登 录 失 败 ! '); window.location href-index php'<lscript>": 
jelsef 
$_SESSION['user]=$_POST['user]; 
echo "<script>alert( 登 录 成 功 ! '); window.location href="main.php';</script>"; 
} 
} 


?> 
(4) 创建 main.php 文件 ， 连 接 数据 库 类 执行 查询 语句 ， 应 用 mysqli_fetch_object0 函 数 和 while 语句 完成 数 
据 库 中 数据 的 循环 输出 ， 其 关键 代码 如 下 : 


<?php 

session start(); 

include("conn/conn.php"):; 

if($_SESSION['user]==true){ 
> 


7 
/| 省 略 部 分 代码 
<2php 

$sql=mysqli_query($conn."select name,email.address from tb_reg "); 
Dm 


Ss 
<td height="22" align="center"><?php echo $obj->name:?></td> 
<td align="center"><?php echo substr($obj->email.0.20):?></td> 
<td align="center"><?php echo $obij->address:?></td> 
</t> 
<?php 
} 


> 
/省 略 部 分 代码 


echo "<script>alert( 您 不 具备 访问 权限 ! '):window ,location href-index.php':</script>": 


2> 


国 秘笈 心 法 


心 法 领悟 457: 返回 查询 结果 集中 的 数据 。 

返回 查询 结果 集中 的 数据 ， 不 但 可 以 使 用 mysqli_fetch_object0 函 数 ， 还 可 以 使 用 mysqli_fetch_array()、 
Imysqli_fetch_assocO0 和 mysqli_fetch row0 函 数 。 

通过 mysqli_fetch_array0 函 数 返 回 的 查询 结果 集 可 以 使 用 数字 索引 或 者 关联 索引 来 读 取 数据 ; 而 通过 
mysqli_fetch_assoc0 函 数 返 回 的 查询 结果 集 必须 使 用 关联 索引 来 获取 数据 ， 通 过 mysqli_fetch_row0 函 数 返回 的 
查询 结果 集 必须 使 用 数字 索引 来 获取 数据 。 
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实例 458 中 数据 的 动态 输出 


力 实例 说 明 


在 本 实例 中 应 用 mysqli 函数 库 中 的 函数 动态 地 对 数据 库 和 数据 表 进 行 操作 ,统计 数据 表 中 的 字段 和 记录 数 ， 
并 且 循 环 输 出 数据 表 中 的 数据 ， 其 运行 结果 如 图 9.12 所 示 。 
入 数据 施 识 六 


FS5:[ 3 
二 共 月 字 生 ;个 如家 并 记录 条 


这 same 


日 


9.12 浏览 注册 用 户 


力 关键 技术 
(1) 统计 查询 结果 中 的 字段 数 应 用 的 是 mysqli_num_fields0 函 数 ， 其 语法 如 下 : 


int mysqli_num ficlds(mysqli_result result) 
参数 result 为 mysqli query0、mysqli_ store _result0 或 mysqli_use_result0 函 数 执行 查询 后 的 返回 值 。 
(2) 统计 查询 结果 中 的 记录 数 应 用 的 是 mysqli_num rows() 函 数 ， 其 语法 如 下 : 


| 
参数 result 为 mysqli query0、mysqli_store_result0 或 mysqli_use_result0 函 数 执行 查询 后 的 返回 值 。 
(3) 获取 数据 表 中 字段 信息 应 用 的 是 mysqli_fetch_fields0 函 数 。 它 返回 一 个 对 象 数 组 ， 该 数组 包含 某 表 字 
段 的 信息 ， 如 果 该 表 的 字段 为 空 ， 则 返回 FALSE， 其 语法 如 下 : 


amray mysqli_fetch_ficlds(mysqli_result result) 


参数 result 为 mysqli_query0 函 数 的 返回 值 ， 返 回 的 对 象 数组 可 以 调用 的 属性 如 表 9.5 所 示 。 
表 9.5 mysqlLfetch_fields() 函 数 返 回 的 对 象 数组 可 以 调用 的 属性 说 明 


属 性 说 了 明 

name 返回 字段 的 名 称 

orgname 返回 字段 的 原始 名 称 
table 返回 字段 所 属 的 表 名 
orgtable 返回 字段 所 属 的 原始 表 名 
def 返回 该 字段 的 默认 值 
max_length 返回 字段 的 最 大 宽度 
length 字段 的 宽度 
charsetnr 返回 字段 所 属 的 字符 集 
flags 返回 一 个 描述 字段 的 位 标记 
type 返回 字段 的 数据 类 型 
decimals 返回 字段 小 数 部 分 的 位 数 
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在 本 实例 中 只 是 应 用 name 属性 ， 获 取 数 据 表 字段 的 名 称 。 
图 设计 过 程 
在 本 实例 中 创建 index.php 文件 。 首 先 创建 form 表单 ， 将 要 访问 的 数据 库 和 数据 表 名 称 提交 到 本 页 。 然 后 


获取 提交 的 数据 库 、 数 据 表 名 称 ， 执 行 连接 操作 ， 连 接 成 功 后 ， 统 计数 据 表 中 字段 和 记录 的 总 数 。 最 后 循环 输 


出 指定 数据 表 中 的 数据 ， 其 关键 代码 如 下 : 
<?php 
if($_POST[submit]!="){ 
$dbname=$_POST[dbname]: 
S$tbname=$_POST[tbname]; 
Sconn=mysqli_connect("localhost","root","111",$dbname); 
imysqli_connect_ emmoO) { 
printft" 数 据 库 连接 失败 : %s\n", mysqli_connect_error0); 
exit0: 


} 

mysqli_query($conn."set names utf8"); 
Sresult=mysqli_query($conn,"select * from ".$tbname.""); 

echo "该 表 共 有 字段 &nbsp:".mysqli_num_ficlds(Sresult)."&nbsp; 个 1"; 
echo "该 表 共有 记录 &nbsp:".mysqli_num_rows(Sresult)."&nbsp: 条 !"; 
} 


> 


<td> 
</tr> 
</table> 
<?php 
if($conn){ 


<table width="$50" bordercolor="#FFFFFF" bgcolor="#FFCC33"> 
<tr> 
<2php 
for($i=0; $i<mysqli_num ficlds(S$result):$i++){ 
$obj=mysqli_fetch_field(Sresult): 
> 
<td height="25" bgcolor="#FFFFFF" ><div align="center"><?php echo $obij->name:?></div></td> 
<?php 
} 
> 
</tr> 
<?php 
$query = "select + from ".$tbname.™"; 
$sql=mysqli_query($conn,$query): 
Sinfo=mysqli_fetch_array($sql): 
if($info—NULL){ 
echo " 暂 无 员工 信息 !"; 
jelse{ 
do 


?> 
< 
<?php 
for($i=0; $i<mysqli num fields($sqD):$i++){ 


<td height="25" bgeolor="#F FFFFF"><div align="center"><?php echo $info[$i]:?></div></td> 


</t> 
<?php 
}while($info=mysqli_fetch_array($sql)): 


mysqli_close($conn); 
> 

</table> 
<?php 
} 


和 
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心 法 领悟 458: 动态 读 取 数据 库 的 优势 。 
动态 读 取 数据 库 可 以 增加 页 面 的 灵活 性 ， 不 必 拘 泥 于 某 个 数据 库 、 数 据 表 的 格式 ， 此 方法 更 适合 于 在 后 台 
管理 系统 中 对 数据 进行 管理 。 


9.2 ”MySQL 视图 的 应 用 


视图 也 称 虚 表 ， 包 括 执行 某 个 查询 返回 的 一 组 记录 。 视 图 可 以 简化 获取 数据 的 方法 ， 并 通过 别名 来 实现 抽 
象 查询 。 


实例 459 趣味 指数 : 请 祖 请 


初级 


实例 说 明 


为 了 简化 查询 、 提 高 系统 安全 性 ， 在 项 目 开发 过 程 中 ， 通 常 采 用 为 数据 库 中 的 某 个 表 建 立 视图 的 方式 。 在 
建立 的 视图 中 只 有 开发 人 员 所 关心 的 字段 。 运 行 本 实例 ， 如 图 9.13 所 示 ， 分 别 在 图 中 输入 登录 用 户 的 用 户 名 和 
密码 ， 单 击 “ 进 入 ”按钮 后 ， 如 果 用 户 输入 的 用 户 名 或 密码 错误 则 给 出 错误 提示 ， 反 之 ， 如 果 输 入 的 用 户 名 和 
密码 正确 ， 则 提示 成 功 登录 。 由 于 本 实例 采用 视图 建立 了 虚 表 ， 所 以 应 首先 在 命令 提示 符 窗 口中 建立 视图 ， 如 
图 9.14 所 示 。 


企业 客服 管理 系统 


图 9.13 用 户 身份 验证 图 9.14 创建 视图 


图 关键 技术 
在 MySQL 中 创建 视图 可 以 通过 create view 语句 来 实现 ， 具 体 创建 格式 如 下 : 


create [ or deplace] [algorithm={merge | temptable | undefined}] view view_name [( column list)] as select_statement [with [cascaded |local] check 
option] 


参数 说 明 : 

view_name: 新 建 视图 的 名 称 。 

select_statement: SQL 查询 语句 ， 用 于 限定 虚 表 的 内 容 。 

algorithm={merge | temptable | undefined} 属 性 用 于 优化 MySQL 视图 的 执行 ， 该 属性 有 3 个 可 用 的 设置 。 下 
面 将 介绍 这 3 个 设置 的 使 用 方法 

merge: 该 参数 将 MySQL 执行 视图 时 传 入 的 任何 子 句 合并 到 视图 的 查询 定义 中 。 

temptable: 如 果 视 图 低层 表 中 的 数据 有 变化 ， 将 在 下 次 通过 表 时 立即 反映 出 来 。 

undefined: 当 查 询 结果 和 视图 结果 为 一 一 对 应 关系 时 ，MYySQL 将 algorithm 设 定 为 temptable。 
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力 设计 过 程 


(1) 建立 数据 库 及 数据 库 表 。 本 实例 中 将 数据 表 命名 为 也 _admin， 其 创建 过 程 可 以 通过 phpMyAdmin 实现 。 
(2) 完成 数据 表 的 创建 后 ， 在 命令 提示 符 下 建立 视图 ， 创 建 视图 的 代码 如 下 : 


create view chkadmin as select name, pwd from tb_admin 
创建 的 视图 chkadmin 中 只 包含 name 和 pwd 两 个 字段 信息 ， 这 样 使 得 程序 的 其 他 字段 信息 不 可 见 ， 从 而 可 
以 有 效 提 高 程序 的 安全 性 。 
(3) 采用 PHP 中 的 MySQL 函数 库 建立 与 MySQL 数据 库 的 连接 。 首 先 使 用 mysql_connect0 函 数 连接 
MySQL 数据 库 ， 然 后 使 用 函数 mysql_select_db0 选 择 数 据 库 db_database09， 最 后 使 用 函数 mysql_query0 执 行 
set names utf8 语句 来 设置 数据 库 的 编码 为 UTF-8 编码 ， 实 现 该 过 程 的 代码 如 下 : 


Sconn=mysql_connect("localhost","root","111"); // 建 立 与 MySQL 数据 库 的 连接 
mysql_select_db("db_database09", Sconn): // 选 择 数据 库 
mysql_query("set names utf8"); // 设 置 数据 库 字符 编码 
(4) 判断 用 户 是 否 单 击 了 “进入 ”按钮 ， 如 果 是 ， 则 通过 视图 chkadmin 对 用 户 身份 进行 验证 ， 该 过 程 的 
代码 如 下 : 
if($_POST[submit]!=""){ 
include_once("conn.php"); // 包 含 conn.php 文件 
Sname=$_POST[name]; // 接 收 提交 的 用 户 名 
Spwd=$_POST[pwd]; // 接 收 提交 的 用 户 密码 
$sql=mysql query("select * from chkadmin where name=".$name." and 
pwd=".$pwd."™",Sconn); // 执 行 查询 
Sinfo=mysql_fetch_array($sql): // 返 回 结果 集 
if($info=false){ /判断 用 户 名 和 密码 是 否 正确 
echo "<script>alert( 用 户 名 或 密码 输入 错误 1"):history.back0;</script>"; 
exit; 
jelse{ 


echo "<br><div align=center> 登 录 成 功 !</div>"; /如 果 正 确 则 提示 登录 成 功 
} 


国 秘笈 心 法 

心 法 领悟 439， 使 用 视图 的 实际 意义 。 

视图 在 项 目 开发 过 程 中 具有 非常 重要 的 实际 意义 ， 主 要 表现 在 如 下 两 点 : 

(1) 使 用 视图 可 以 使 查询 更 加 简化 。 在 程序 编写 中 , 如 果 所 要 执行 的 查询 较为 复杂 , 可 以 将 其 转化 为 视图 ， 
从 而 简化 查询 。 

(2) 使 用 视图 还 可 以 提高 程序 的 安全 性 。 如 果 只 想 让 用 户 访问 某 表 中 的 某 几 个 指定 的 字段 ， 可 以 创建 一 个 
只 包含 这 些 字 段 的 视图 ， 而 不 用 将 整个 表 的 所 有 字段 的 访问 权限 都 分 配给 该 用 户 。 


Cg 技巧 : 虽然 不 使 用 视图 也 可 以 完成 对 数据 库 的 操作 ， 但 在 字段 数量 较 多 或 安全 性 要 求 较 高 的 模块 中 建议 通 
过 视图 完成 查询 ， 从 而 有 效 地 提高 程序 的 可 维护 性 和 安全 性 。 


力 实例 说 明 


通过 本 实例 主要 讲解 如 何 对 已 经 创建 完成 的 MySQL 视图 进行 修改 ， 在 制作 本 实例 时 ， 首 先 需 要 在 数据 库 
中 创建 数据 表 tb_changeview， 其 结构 如 图 9.15 所 示 , 然后 创建 视图 userinfo, 该 视图 中 包含 tb_changeview 表 中 
的 所 有 字段 ， 完 成 上 述 操作 后 ， 使 用 alter view 语句 对 视图 进行 修改 。 


趣味 指数 : 依 癸 请 
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字 及 类 型 属性 Null 默认 籁 外 摊 作 
| mg) au menat 畔 户 X 图 民国 于 
memmame varrhar50y on2312 到 | 区 习 | 沪 |X| 加 | 加 | 加 | 加 
三 ”wserpwdl warcnar50 ob2312_thness_cl 至 必 上 XX 图 轩 回国 


图 9.15 创建 表 changeview 


图 关键 技术 


在 MySQL 中 修改 视图 可 以 通过 alter view 语句 实现 ，alter view 语句 的 具体 使 用 说 明 如 下 : 


alter view [algorithm={merge | temptable | undefined} Jview view_name [(column list)] as select_statement[with [cascaded | local] check option] 
参数 说 明 : 

algorithm: 该 参数 已 经 在 创建 视图 中 作 了 介绍 ， 这 里 不 再 次 述 。 

view_name: 视图 的 名 称 。 

select_statement: SQL 语句 ， 用 于 限定 视图 。 


图 设计 过 程 
(1) 使 用 phpMyAdmin 创建 数据 库 及 数据 库 表 ， 本 实例 中 将 数据 表 命 名 为 tb_changeview。 
(2) 使 用 create view 语句 创建 视图 userinfo， 其 创建 代码 如 下 : 


create view userinfo as select * from tb_changeview 


(3) 使 用 select 语句 查询 视图 userinfo， 查 询 代码 如 下 : 


select * from userinfo 
查看 执行 结果 ， 可 以 发 现 tb_changeview 表 中 的 所 有 字段 都 一 一 列 出 ， 如 图 9.16 所 示 。 
(4) 下 面 开 始 修改 视图 ， 要 求 修改 后 只 列 出 usermame 字段 ， 代 码 如 下 : 


I 
(5) 重新 查询 视图 userinfo， 从 结果 中 可 以 发 现 ,此 时 只 列 出 username 一 个 字段 ， 从 而 说 明 视 图 修改 成 功 ， 
如 图 9.17 所 示 。 


图 9.16 创建 新 视图 图 9.17 修改 视图 


人 注意 : 如 果 数 据 库 采用 UTF-8 编码 ， 在 命令 提示 符 下 通过 select 语句 显示 查询 结果 时 会 出 现 中 文 乱码 现象 。 
力 秘笈 心 法 


心 法 领悟 460: 在 phpMyAdmin 的 查询 窗口 中 创建 和 修改 视图 。 
在 实现 本 实例 时 ， 创 建 视图 的 过 程 是 在 Windows 系统 的 命令 提示 符 窗口 中 实现 的 ， 为 了 提高 开发 效率 、 简 
化 程序 开发 人 员 的 操作 , MySQL 数据 库 的 创建 和 维护 过 程 一 般 在 MySQL 的 图 形 管理 工具 phpMyAdmin 中 进行 ， 
phpMyAdmin 为 MySQL 数据 库 提供 了 较为 完善 的 创建 、 维 护 及 备份 等 操作 。 同 样 ， 如 果 使 用 phpMyAdmin 的 
查询 窗口 也 可 以 执行 SQL 命令 ， 所 以 可 以 在 该 查询 窗口 中 创建 视图 ， 其 具体 创建 过 程 如 下 : 
(1) 打开 phpMyAdmin 管理 页 面 并 选择 要 管理 的 数据 库 ， 单 击 如 图 9.18 所 示 的 “查询 窗口 ”按钮 打开 
phpMyAdmin 的 查询 窗口 。 
(2) phpMyAdmin 的 查询 窗口 如 图 9.19 所 示 ， 可 以 在 该 窗口 中 输入 SQL 命令 实现 对 指定 数据 库 及 表 的 查 
询 操作 。 例 如 在 该 查询 窗口 中 输入 创建 视图 的 SQL 命令 ， 然 后 单 击 图 中 的 “执行 ”按钮 即 可 成 功 地 实现 视图 的 
创建 操作 。 
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厂 不 从 定 口 让 有 三 北 豆 请 | Deliiter[ ”””] 所 在 比 至 次 显示 此 音 询 | | 
Ss [ | nt 加 
图 9.19 在 查询 窗口 中 执行 SQL 命令 
初级 | 
实例 | 
实例 461 趣味 指数 : 依 癸 傅 
力 实例 说 明 


本 实例 主要 讲解 如 何 通 过 SQL 命令 删除 MySQL 视图 。 与 创建 MySQL 视图 相同 ， 删 除 MySQL 视图 可 以 
在 Windows 的 命令 行 或 phpMyAdmin 的 命令 窗口 中 通过 SQL 命令 实现 ， 本 实例 将 讲解 在 Windows 的 命令 行 下 
通过 drop view 命令 删除 MySQL 数据 库 中 视图 的 方法 。 


力 关键 技术 


在 MySQL 数据库 中 ， 可 以 通过 drop view 命令 删除 MySQL 数据 库 中 已 创建 的 视图 ,该 SQL 命令 的 语法 格式 如 下 : 


drop view [if exists] view_name 


在 上 述 命令 中 ，ifexists 子 句 用 于 维护 查询 ， 防 止 因 要 删除 的 视图 不 存在 而 发 生 错 误 。 
力 设计 过 程 

(1) 打开 命令 提示 符 窗口 ， 如 图 9.20 所 示 ， 首 先 使 用 mysql 命令 连接 并 登录 MySQL 数据 库 ， 在 命令 窗口 
中 输入 如 下 语句 : 


mysql -uroot —proot; 


登录 MySQL 数据 库 后 ， 使 用 use 命令 选择 数据 库 db_database09， 然 后 创建 视图 testview， 代 码 如 下 : 


create view testview as select * from tb_test 


创建 完 视图 testview 后 ， 使 用 select 语句 查看 视图 ， 从 图 9.20 的 运行 结果 可 知 ， 视 图 已 经 被 成 功 创建 。 
(2) 使 用 drop view 语句 删除 已 经 创建 的 testview 视图 ， 实 现代 码 如 下 : 


drop view testview 


删除 视图 testview 后 ， 再 次 使 用 select 语句 查询 ， 将 出 现 如 图 9.21 所 示 的 错误 提示 。 


图 9.20 在 命令 提示 符 下 创建 视图 图 9.21 错误 提示 
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心 法 领悟 461: 在 phpMyAdmin 的 命令 窗口 中 删除 视图 。 
要 删除 指定 的 视图 , 可 以 在 phpMyAdmin 的 命令 窗口 中 实现 。 首先 打开 phpMyAdmin 的 命令 窗口 , 如 图 9.22 
所 示 ， 然 后 在 该 窗口 中 输入 drop view 语句 ， 最 后 单 击 “ 执 行 ” 按 钮 即 可 成 功 删除 指定 的 视图 。 


Run SQL queryoueries on sever ocalhost Bo 
ldrop view testview 


1 
BE me 


图 9.22 在 phpMyAdmin 的 命令 窗口 中 删除 视图 


实例 462 


力 实例 说 明 


在 实际 项 目 开发 过 程 中 数据 表 中 可 能 有 很 多 字段 ， 但 某 个 模块 可 能 只 需要 其 中 的 几 个 。 为 了 提高 查询 速度 
和 简化 操作 ， 可 以 将 该 模块 需要 的 字段 单独 提取 出 来 放 在 某 个 视图 中 ， 例 如 本 实例 涉及 学 生 表 和 成 绩 表 ， 在 建 
立 的 视图 中 只 含有 与 学 生成 绩 有 关 的 字段 ， 如 图 9.23 所 示 。 

运行 本 实例 ， 如 图 9.24 所 示 ， 图 中 查询 结果 显示 的 内 容 即 为 视图 中 所 有 字段 中 的 内 容 。 


视图 的 应 用 
16 至 星 星 上 中 但 
05312317 苗 少 全 S56 加 
| 用 
图 9.23 创建 视图 图 9.24 学 生成 绩 列表 


图 关键 技术 


本 实例 创建 的 视图 涉及 多 表 查 询 ， 这 说 明 多 个 表 之 间 可 以 通过 视图 来 组 合 为 一 个 整体 ， 这 样 对 视图 的 操作 
就 相当 于 多 表 查 询 。 但 如 果 这 些 表 中 有 相同 的 字段 ， 必 须 按 如 下 方式 书写 重 名 的 字段 : 

表 名 1 字段 名 . 表 名 2. 字段 名 … 
图 设计 过 程 

(1) 创建 视图 scoreinfo， 通 过 该 视图 显示 学 生成 绩 信息 ， 该 视图 的 创建 代码 如 下 : 


create view scoreinfo as select sno.sname yw:wy:sx from tb_student.tb_score where tb_student.id=tb_score.sid 
(2) 建立 数据 库 连接 文件 conn.php， 实 现 与 MySQL 数据 库 的 连接 ， 并 设置 数据 库 字 符 集 为 UTF-8 编码 ， 
代码 如 下 : 
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Sconn=new mysqli("localhost","root"."111"."db_database09"): // 建 立 与 MySQL 数据 库 的 连接 


Sconn->query("set names utf8"); // 设 置 数据 库 字 符 编码 
(3) 查询 视图 scoreinfo 中 的 内 容 并 显示 查询 结果 ， 代 码 如 下 : 
<Iphp 
include_once("conn.php"): /包含 conn php 
$sql=$conn->query("select * from scoreinfo"): /执行 查询 
$info=$sql->fetch_array(MYSQLI ASSOC); /获得 查询 结果 集 
if($info—NULL){ // 判 断 是 否 查 询 到 成 绩 信息 
echo " 暂 无 学 生 信息 "; 
yelse{ 
dof // 通 过 循环 打印 学 生成 绩 信息 
?> 


<t> 
<td height="20" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[sno]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[sname]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[yw]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $info[wy]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo $infofsx];?></div></td> 
<i> 
}while(Sinfo=$sql->fetch_array(MYSQLI_ASSOC)): 


?> 


图 秘笈 心 法 


心 法 领悟 462: 使 用 do...while 循环 打印 学 生成 绩 信息 。 

本 实例 之 所 以 使 用 do…while 循环 语句 是 因为 该 语句 先 执行 循环 体 ， 然 后 再 判断 while 中 的 条 件 是 否 为 真 。 
在 执行 循环 之 前 已 经 调用 过 一 次 fetch_array0 方 法 ， 那 么 记录 指针 应 该 指向 第 2 条 记录 位 置 ， 如 果 使 用 while 循 
环 会 遗漏 第 1 条 记录 。 


9.3 MySQL 存储 过 程 


MySQL 5.0 以 后 的 版 本 开始 支持 存储 过 程 ， 存 储 过 程 具有 一 致 性 、 高 效 性 、 安 全 性 和 体系 结构 等 特点 ， 本 
节 将 通过 具体 实例 讲解 PHP 是 如 何 操纵 MySQL 存储 过 程 的 。 


0 ee 
实例 463 趣味 指数 : 请 博 请 | 
图 实例 说 明 


为 了 保证 数据 的 完整 性 、 一 致 性 ， 提 高 应 用 的 性 能 ， 常 采用 存储 过 程 技术 。MySQL 5.0 之 前 的 版 本 并 不 支 
持 存 储 过 程 ， 随 着 MySQL 技术 的 日 趋 完善 ， 存 储 过 程 逐 渐 得 到 广泛 的 应 用 。 本 实例 将 介绍 如 何在 MySQL 5.0 
以 后 的 版 本 中 创建 存储 过 程 。 


图 关键 技术 


一 个 存储 过 程 包 括 名 字 、 参 数列 表 以 及 可 以 包括 很 多 SQL 语句 的 SQL 语句 集 。 下 面 为 一 个 存储 过 程 的 定 
义 过 程 : 

create procedure proc name (in parameter integer) 

begin 

declare variable varchar(20): 

证 parameter=l then 

set variable=MySQL': 
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endif: 

i ee values (variable): 

在 MySQL 中 ， 存 储 过 程 的 建立 以 关键 字 create procedure 开始 ， 后 面 紧 跟 存储 过 程 的 名 称 和 参数 。 MySQL 
的 存储 过 程 名 称 不 区 分 大 小 写 ， 例 如 PROCE10 和 proce10 代 表 同 一 存储 过 程 名 。 存 储 过 程 名 不 能 与 MySQL 数 
据 库 中 的 内 建 函数 重 名 。 

存储 过 程 的 参数 一 般 由 3 部 分 组 成 。 第 一 部 分 可 以 是 加 、out 或 inout。n 表示 向 存储 过 程 中 传 入 参数 ，out 
表示 向 外 传 出 参数 ，inout 表示 定义 的 参数 可 传 入 存储 过 程 并 可 以 被 存储 过 程 修改 后 传 出 ， 存 储 过 程 默 认为 传 入 
参数 ， 所 以 参数 in 可 以 省 略 。 第 二 部 分 为 参数 名 。 第 三 部 分 为 参数 的 类 型 ， 该 类 型 为 MySQL 数据 库 中 所 有 可 
用 的 字段 类 型 ， 如 果 有 多 个 参数 ， 参 数 之 间 可 以 用 逗号 进行 分 隔 。 

MySQL 存储 过 程 的 语句 块 以 begin 开始 ， 以 end 结束 。 语 句 体 中 可 以 包含 变量 的 声明 、 控 制 语句 、SQL 查 
询 语句 等 。 由 于 存储 过 程 内 部 语句 要 以 分 号 结束 ， 所 以 在 定义 存储 过 程 前 应 将 语句 结束 标志 “;” 更 改 为 其 他 字 
符 ， 并 且 该 字符 应 该 在 存储 过 程 中 出 现 的 几率 较 低 ， 可 以 用 关键 字 delimiter 转换 ， 例 如 : 


mysql>delimiter // 


存储 过 程 创建 之 后 ， 可 用 如 下 语句 进行 删除 : 
drop procedure proc_name 


参数 proc_name 指 存储 过 程 名 。 
图 设计 过 程 
MySQL 存储 过 程 是 在 命令 提示 符 下 创建 的 ， 所 以 首先 应 该 打开 命令 提示 符 窗口 。 


(1) 进入 命令 提示 符 窗口 后 ， 首 先 应 该 登录 MySQL 数据 库 服务 器 ， 在 命令 提示 符 下 输入 如 下 命令 : 
mysql-u 用 户 名 -p 用 户 密码 


(2) 更 改 语句 结束 符号 。 本 实例 将 语句 结束 符 更 改 为 “//”， 代 码 如 下 : 


delimiter // 


EA 代码 如 下 : 


use 数 


(4) 创建 存储 过 程 。 
(5) 通过 call 语句 调用 存储 过 程 。 


国 秘笈 心 法 


心 法 领悟 463: 使 用 存储 过 程 的 优点 。 

(1) 使 用 存储 过 程 进行 项 目 开发 可 以 提高 程序 的 可 移植 性 。 在 存储 过 程 中 ， 可 以 编写 事务 处 理 逻 辑 ， 并 可 
以 被 其 他 程序 所 重用 。 

(2) 存储 过 程 可 以 节省 大 量 的 工作 ， 不 需要 重复 执行 同样 的 逻辑 运算 。 


用 户 登 初级 
sn | “Tm ee 
图 实例 说 明 


通过 本 实例 主要 讲解 如 何 使 用 MySQL 存储 过 程 实现 用 户 登录 身份 的 验证 。 运 行 本 实例 ， 如 图 9.25 所 示 ， 
在 图 中 登录 窗口 的 文本 框 中 输入 用 户 名 和 密码 ， 然 后 单 击 “登录 ”按钮 ， 如 果 用 户 录入 的 用 户 名 和 密码 正确 ， 
则 会 将 页 面 定 向 到 如 图 9.26 所 示 的 登录 成 功 提示 页 。 
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图 9.25 用 户 登 录 窗 口 图 9.26 登录 成 功 的 提示 信息 


图 关键 技术 


在 创建 本 实例 的 存储 过 程 中 ， 为 了 防止 结束 符 冲 突 ， 首 先 使 用 delimiter 语句 将 MySQL 默认 的 结束 符 “;” 
更 改 为 “//”， 然 后 创建 存储 过 程 ， 其 创建 代码 如 图 9.27 所 示 。 


图 9.27 创建 用 户 登录 验证 的 存储 过 程 


创建 完成 上 述 存储 过 程 后 ， 在 程序 中 使 用 call 语句 调用 要 执行 的 存储 过 程 ， 本 实例 使 用 MySQLi 扩展 库 执 
行 存储 过 程 ， 其 实现 代码 如 下 : 

$sql = $mysqli->query("call pro_login(™.$usemame.™, ".$password.")"): 
看 设计 过 程 


(1) 通过 MySQLi 扩展 库 建立 与 MySQL 数据 库 的 连接 ， 并 设置 数据 库 字 符 集 为 UTF-8， 实 现代 码 如 下 : 
Smysqli=new mysqli("localhost", "root","111"."db_database09"): 建立 与 MySQL 数据 库 的 连接 
Smysqli->query("set names utf8"); 设置 数据 库 字 符 编码 为 UTF-8 


(2) 建立 用 户 登录 表单 ， 当 用 户 在 表单 中 录入 用 户 名 和 密码 ， 并 单 击 “提交 ”按钮 后 ， 通 过 如 下 代码 验证 
用 户 的 登录 信息 是 否 正 确 : 


ifisset($_POST[usemame]) && trim($_POST['usemame"])!=") 判断 用 户 是 否 提交 了 表单 
require_once ‘Db.php': 包含 Db.php 文件 
S$usemame = trim($_ POST[usemame]): 获得 提交 的 用 户 名 
S$password = trim($_POST['password']); /获得 提交 的 用 户 密码 
$sql = $mysqli->query("call pro_login(".Susemame.", ".$password.")"): 调用 存储 过 程 ， 执 行 查询 
S$info = $sql->fetch_array(MYSQLI ASSOC): 获得 查询 第 一 条 记录 
if($info (= nulD{ 判断 是 否 为 NULL 值 
$_SESSION['loginUsemame'] = Susemame: 将 用 户 名 保存 到 SESSION 中 
echo ‘<script>window.location.href="success.php":</script>"; 重 定向 到 successphp 页 面 
Jelse { 


echo '<div style="width:300px: height:30px: line-height:30px: border:1px solid #FE59B04: background-color:#FCF2E0:; color 红 F0000:"> 用 户 
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名 或 密码 输入 有 误 </div>': // 提 示 用 户 登录 信息 错误 
} 


} 

上 述 代 码 中 ， 首 先 判 断 $_POST["usermame'] 的 值 是 否 被 设置 ， 如 果 是 ， 则 首先 使 用 require_once 语句 包含 
Db.php 文件 ， 然 后 使 用 MySQLi 扩展 库 的 query0 方 法 执行 存储 过 程 pro_ login， 并 使 用 query0 方 法 所 返回 的 对 
象 调用 fetch_array0 获 得 结果 集 ， 最 后 通过 判断 结果 集 是 否 为 NULL 来 判断 用 户 所 录入 的 信息 是 否 正确 。 


心 法 领悟 464: 备份 已 经 定义 存储 过 程 的 数据 库 。 

一 般 情况 下 ， 如 果 备 份 MySQL 中 指定 的 数据 库 通 过 如 下 命令 即 可 实现 : 

mysqldump —uroot -proot db_database09 > c:/data.sql 

但 是 如 果 在 MySQL 数据 库 中 定义 了 存储 过 程 , 通过 上 述 命令 不 能 将 存储 过 程 一 同 备份 , 那么 如 何 解决 呢 ? 
可 以 在 上 述 命令 中 加 上 “-R” 选 项 ， 代 码 如 下 : 

mysqldump -uroot —proot -R db_database09 > c:/data.sql 


实例 465 


实例 说 明 


在 数据 库 系统 开发 过 程 中 ， 应 用 存储 过 程 可 以 使 整个 系统 的 运行 效率 有 明显 的 提高 ， 本 实例 将 向 读者 介绍 
MySQL 5.0 版 本 中 存储 过 程 的 创建 以 及 PHP 调用 MySQL 存储 过 程 的 方式 。 运 行 本 实例 前 首先 应 在 命令 提示 符 
下 创建 如 图 9.28 所 示 的 存储 过 程 ， 然 后 运行 本 实例 ， 如 图 9.29 所 示 ， 在 图 中 的 文本 框 中 输入 注册 信息 后 ， 单 击 

“注册 ”按钮 即 可 将 用 户 填写 的 注册 信息 保存 到 数据 库 中 ， 最 终 保存 结果 如 图 9.30 所 示 。 


Eg 


图 9.28 创建 存储 过 程 图 9.29 录入 注册 信息 


Te pa Ey Er 
口 PX 1 meh 25455ad285sa400aW64c76d71360734 jnu_ahrG@163 tom 表 条 长 罕 


图 9.30 注册 信息 被 存储 到 MySQL 数据 库 


力 关键 技术 
本 实例 的 关键 技术 是 如 何 创建 传 入 参数 的 存储 过 程 ， 具 体 实现 代码 如 下 : 


delimiter // 

create procedure pro_reg (in ne varchar(50). in pwd varchar(50), in email varchar(50).in address varchar(50)) 
begin 

insert into tb reg (name. pwd ,email .address) values (ne. pwd email, address): 

end: 

内 

delimiter /: 将 语句 结束 符 更 改 为 “//”。 

in nc varchar(50)..…,in address varchar(50): 表示 要 向 存储 过 程 中 传 入 的 参数 。 


begin.…end: 表示 存储 过 程 中 的 语句 块 ， 其 作用 类 似 于 PHP 语言 中 的 “1{...}”。 
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力 设计 过 程 


(1) 通过 PHP 预定 义 类 mysqli 实现 与 MySQL 数据 库 的 连接 ， 代 码 如 下 : 
Sconn=new mysqli("localhost". "root","111"."db_database09"); 
Sconn->query("set names utf8"); 

(2) 调用 存储 过 程 pro_reg 实现 将 用 户 录入 的 注册 信息 保存 到 数据 库 ， 代 码 如 下 : 
if($sql=$conn->query("call pro_reg(".$ne.™,". Spwd.™,".$email.™,".$address.")")){ 

echo "<script>alert( 用 户 注册 成 功 !);</script>"; 
}else{ 
echo "<seript>alert( 用 户 注册 失败 ;</script>"; 

} 


秘笈 心 法 

心 法 领悟 465: 使 用 PDO 数据 库 抽象 类 执行 存储 过 程 。 

实现 本 实例 时 ,使 用 MySQLi 扩展 库 执行 存储 过 程 ， 除 使 用 该 方法 外 ， 还 可 以 使 用 PDO 数据 库 抽象 类 执行 
存储 过 程 , 在 实现 本 实例 时 , 可 以 将 保存 用 户 注册 信息 的 代码 进行 如 下 更 改 , 来 演示 使 用 PDO 技术 执行 MySQL 
存储 过 程 的 方法 。 

$db = new PDO('mysql:host=localhost:dbname=db_database09', root', root); /实例 PDO 类， 连接 MySQL 数据 库 

$stmt = $db->prepare("call pro_reg(?. ?, ?, ?)"); // 建 立 查询 的 预 处 理 句 柄 

$stmt->bindParam(1.$_ POST[me]); // 饰 定 参 数 

$stmt->bindParam(2, $_POST[pwd]): 


Sstmt->bindParam(3, $_POST['email]); 
Sstmt->bindParam(4, $_POST['address']); 


$stmt->execute(); /执行 查询 
| 说 明 : 使 用 PDO 连接 MySQL 数据 库 时 ， 连 接 字 符 串 mysql:host=localhost:dbname=db_database09 中 内 容 的 
顺序 可 以 颠倒 。 


9.4 MySQL 触发 器 


触发 器 在 数据 库 系 统 开发 过 程 中 具有 非常 重要 的 作用 ， 例 如 可 以 防止 有 害 数 据 录 入 数据 库 、 可 以 改变 或 取 
消 insert、update 和 delete 语句 的 执行 及 在 一 个 会 话 中 监听 数据 库 中 的 数据 的 改变 。 


实例 466 


国 实例 说 明 


如 果 用 户 打 算 在 数据 库 中 通过 触发 器 实现 某 一 动作 的 监听 ， 那 么 首先 应 该 创建 触发 器 。 触 发 器 是 在 命令 提 
示 符 下 创建 的 ， 如 图 9.31 所 示 。 


图 9.31 触发 器 创建 过 程 
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图 关键 技术 


MySQL 数据 库 中 创建 触发 器 的 格式 如 下 : 
create trigger < 触发 器 名 称 > 

{ before | after} 

{insert | update | delete} 

for each row 

< 触发 器 SQL 语句 > 


参数 说 明 : 
create trigger < 触发 器 名 称 >: 创建 一 个 新 触发 器 ， 并 指定 触发 器 的 名 称 。 
{ before | after}: 用 于 指定 在 insert、update 或 delete 语句 执行 前 触发 还 是 在 语句 执行 后 触发 。 
on < 表 名 >: 用 于 指定 响应 该 触发 器 的 表 名 。 
for each row: 触发 器 的 执行 间隔 。for each row 通知 触发 器 每 隔 一 行 执行 一 次 动作 , 而 不 是 对 整个 表 执行 一 次 。 
< 触发 器 SQL 语句 >: 触发 器 要 执行 的 SQL 语句 。 
用 设计 过 各 
(1) 在 命令 提示 符 下 创建 数据 表 tb_test， 代 码 如 下 : 
create table tb_test(t_id varchar(20).t_name varchar(20)) 
(2) 将 换行 标记 转换 为 “//”， 代 码 如 下 : 
delimiter // 


(3) 创建 触发 器 ， 实 现 无 论 用 户 向 表 tb_test 添加 什么 数据 都 使 字段 t name 的 内 容 为 mrsoft， 代 码 如 下 : 
create trigger test_tri 
before insert on tb_test 
for each row 
set new.t_name="mrsoft’ 
(4) 向 表 tb_test 中 添加 一 条 记录 ， 并 查看 结果 ， 代 码 如 下 : 
insert into tb_test(t_id,t_name) values(‘mr0001', '123")// 
Select * from tb_test 


图 秘笈 心 法 
心 法 领悟 466: 触发 器 中 执行 多 条 SQL 语句 。 
如 果 该 触发 器 要 执行 多 条 SQL 语句 ， 要 将 多 条 语句 放 在 begin...end 块 中 。 


初级 
趣味 指数 : 让 相信 


实例 467 


力 实例 说 明 


在 MySQL 数据 库 中 创建 触发 器 前 应 先 查 看 数据 库 中 的 触 
发 器 ， 这 样 既 可 以 使 开发 人 员 对 指定 的 数据 库 中 的 所 有 触发 器 
及 其 功能 有 一 个 直观 的 把 握 ， 而 且 可 以 避免 创建 同名 或 类 似 功 
能 的 触发 器 。 运 行 本 实例 ， 如 图 9.32 所 示 ， 首 先 在 图 中 的 文本 
框 中 输入 要 查看 触发 器 的 数据 库 名 称 ， 然 后 单 击 “ 查 看 ”按钮 ， 
即 可 将 该 数据 库 中 所 有 触发 器 的 详细 信息 显示 出 来 。 图 9.32 查看 触发 器 


力 关键 技术 
查看 MySQL 数据 库 中 触发 器 的 详细 信息 ， 可 以 通过 如 下 语句 实现 : 
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show triggers 


使 用 show triggers 语句 前 应 先 指明 要 查看 的 数据 库 。 
图 设计 过 程 
(1) 小 返 妥 查 看 航 发 天 的 数据 库 ， 代码 如 下 : 


ect( 
mysql_select_db($dbname.Sconn): 
mysql_query("set names utf8"); 


(2) 执行 show trigger 语句 并 显示 所 查找 到 的 触发 器 的 详细 信息 ， 代 码 如 下 : 


<?php 
$sql=@mysql._query("show triggers",Sconn); 


1 fetch array($sql); 

if(Sinfo—false) { 
?> 
<t> 

<td height="25" colspan="5" bgcolor="#FFFFFF"><div align="center"> 该 数据 库 没 有 设置 触发 器 !</div></td> 
</t> 
<?php 
Jelse{ 

dof 
?> 
<t> 


<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[ Trigger]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[Table]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[Event]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[Timing];?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[Statement]:;?></div></td> 
</Itr> 


<?php 
jwhile($info=mysql_fetch_array($sqD); 
} 


力 秘笈 心 法 


心 法 领悟 467: 用 “@ ”屏蔽 运行 期 错误 。 
在 程序 运行 时 ， 有 时 会 难以 避免 地 出 现 运行 期 错误 并 在 页 面 中 打印 错误 信息 ，PHP 提供 了 “@” 关 键 字 来 
屏蔽 运行 期 错误 ， 只 要 在 可 能 发 生 运 行 期 错误 的 代码 前 加 上 “@” 即 可 。 


[加 说 明 : 可 以 通过 try...catch 语句 捕获 程序 运行 时 异常 。 
9.5 MySQL 事务 


事务 处 理 机 制 在 程序 开发 过 程 中 有 着 非常 重要 的 作用 ， 它 可 以 使 整个 系统 更 加 安全 。 例 如 ， 在 银行 处 理 转 
账 业务 时 ， 如 果 A 账户 中 的 金额 刚 被 发 出 ， 而 B 账户 还 没 来 得 及 接受 就 发 生 停电 ， 会 给 银行 和 个 人 带 来 很 大 的 
经 济 损失 。 采 用 事务 处 理 机 制 ， 一 旦 在 转账 过 程 中 发 生意 外 ， 则 程序 将 回 滚 不 做 任何 处 理 。 


|] 
图 实例 说 明 


MySQL 数据 库 中 的 表 可 以 通过 主键 相互 关联 ， 例 如 学 生成 绩 管理 系统 中 ， 学 生 表 和 成 绩 表 可 以 通过 id 实 
现 关 联 ， 所 以 在 删除 某 个 学 生 信息 时 ， 只 需 删除 这 两 个 表 中 为 该 id 的 所 有 记录 即 可 。 但 是 ， 如 对 成 绩 表 实现 了 
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删除 相关 id 的 工作 后 ， 还 没 来 得 及 删除 学 生 信息 表 中 该 学 生 的 信息 时 就 发 生 停电 等 意外 ， 则 再 重新 查找 该 学 生 
的 成 绩 时 是 无 法 查找 到 的 。 

本 实例 将 采用 事务 处 理 方式 ， 对 学 生 信息 表 和 学 生成 绩 表 中 的 数据 进行 删除 。 运 行 本 实例 ， 学 生 信息 及 学 
生成 绩 信息 分 别 如 图 9.33 和 图 9.34 所 示 。 当 删除 图 9.33 中 的 学 生 信息 后 ， 查 看 学 生成 绩 信息 时 可 以 发 现 ， 与 
该 学 生 对 应 的 成 绩 也 被 全 部 删除 。 


IT 
图 9.33 查看 学 生 信息 图 9.34 查看 学 生成 绩 
图 关键 技术 


事务 的 处 理 可 以 通过 PHP 的 预定 义 类 mysqli 的 以 下 方法 实现 。 

(1) autocommit(boolean): 该 方法 用 于 限定 查询 结果 是 否 自动 提交 ， 如 果 参 数 为 true 则 自动 提交 ， 如 果 参 
数 为 false 则 关闭 自动 提交 。MySQL 数据 库 默 认为 自动 提交 。 

(2) rollback(): 利用 mysqli 类 中 的 该 方法 可 以 实现 事务 的 回 滚 。 

(3) commitO0: 利用 该 方法 可 以 实现 提交 所 有 查询 。 


力 设计 过 程 


(1) 建立 数据 库 及 数据 表 并 实现 与 数据 的 连接 ， 代 码 如 下 : 
Sconn=new mysqli("localhost", "root","111","db_database09"); 
S$conn->query("set names utf8"); 
(2) 显示 所 有 学 生 的 基本 信息 ， 代 码 如 下 : 
<?php 
include_once("conn.php"); 
$sql=$conn->query("select * from tb_stu"); 
S$info=$sql->fetch_array(MYSQLI_ASSOC); 
if($info—NULL){ 
echo " 暂 无 学 生 信息 !"; 
jslse{ 
dof 
?> 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[sname]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[sno]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[sage]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[saddress]:?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[ssfzh]:?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><a hre 仁 "javascript:if(window.confirm( 确 定 删除 该 学 生 信息 
么 ?) 一 true){fwindow location href='delete.php?id=<?php echo $info[id]:?>:}"> 删 除 </a></div></td> 
</t> 
php 
}while($info=$sql->fetch array(MYSQLI ASSOC)): 


?> 

在 实现 该 模块 功能 时 ， 可 以 利用 JavaScript 实现 该 页 与 delete.php 页 面 的 信息 传递 ， 代 码 如 下 : 

<a hre 全 "javascriptiiftwindow.confirm(' 确 定 删除 该 学 生 信息 么 ?2) 一 tme){fwindow.location hre 人 delete .php?id=<?php echo $info[id]:?>':}"> 删 除 </a> 
window 对 象 的 confirm0 方 法 用 于 弹出 一 个 对 话 框 ， 提 示 用 户 是 否 真正 删除 某 学 生 的 所 有 信息 。 


(3) 利用 事务 处 理 机 制 对 学 生 的 基本 信息 进行 删除 ， 代 码 如 下 : 
Sid=$ GET[id]: 
include_once("conn.php"): 
S$conn->autocommit(false): 
if(!$conn->query("delete from tb_sco where id=".$id.™")){ 
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Seonn->rollback0: 

} 

if(!$conn->query("delete from tb_stu where id=".$id."")){ 
Sconn->rollback(); 

} 


$conn->commit(); 
$conn->autocommit(true); 
echo "<script>window.location.href='index.php';</script>"; 


秘笈 心 ; 
心 法 领悟 468 使 用 PDO 数据 库 抽象 类 执行 批 处 理事 务 。 


本 实例 使 用 MySQLi 扩展 库 实现 对 MySQL 数据 库 事务 的 处 理 ， 而 使 用 PDO 数据 库 抽象 类 同样 可 以 实现 此 
功能 ， 其 示例 代码 如 下 : 


$db = new PDO('mysql:host=localhost;dbname=db_database09', root''root): /实例 PDO 类 ， 连 接 MySQL 数据 库 
$db->beginTransaction(); // 开 启事 务 
$db->query($sqll); 1/ 执行 查询 1 
$db->query($sql2); // 执 行 查询 2 
$db->commit(); /提交 查询 
} catch (PDOException $e) { 
$db->rollBack(); /事务 回 滚 
echo $e->getMessage(); 


} 

上 述 代 码 中 ， 首 先 使 用 new 关键 字 对 PDO 类 进行 实例 化 并 返回 PDO 对 象 ， 并 使 用 PDO 对 象 的 
beginTransaction() 方 法 开启 事务 ， 然 后 执行 多 条 查询 语句 ， 最 后 使 用 PDO 对 象 的 commit() 方 法 提交 事务 。 在 上 
述 操作 中 使 用 try.…catch 语句 判断 是 否 发 生 了 异常 ， 如 果 是 则 调用 PDO 对 象 的 rollBack( 方 法 对 事务 进行 回 滚 。 


趣味 指数 寅 丰 
图 实例 说 明 


在 实现 银行 转账 过 程 中 ， 发 生意 外 是 在 所 难免 的 ， 为 了 避免 因 意外 而 造成 不 必要 的 损失 ， 在 银行 转账 时 经 
常 使 用 事务 处 理 方式 。 运 行 本 实例 ， 如 图 9.35 所 示 ， 在 图 中 的 文本 框 中 输入 要 转 给 B 账户 的 金额 后 ， 单 击 “ 转 
账 ”按钮 即 可 实现 转账 。 


图 9.35 银行 转账 
图 关键 技术 
本 实例 的 关键 技术 是 如 何 应 用 PHP 的 事务 处 理 机 制 处 理 转账 过 程 中 可 能 遇 到 的 意外 。 应 用 事务 实现 转账 的 
代码 如 下 : 
S$tob=$_POST[tob]: // 接 收 提交 的 转账 金额 


include_once("conn.php"); // 包 含 数据 库 连接 文件 conn.php 
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S$conn->autocommit(false): // 取 消 查询 自动 提交 


if(!$conn->query("update tb_zy set money=money-".$tob." where flag="mrsoft”")){ /减少 指定 账户 所 要 转账 的 金额 
S$conn->rollback(); /如 果 失 败 则 事务 回 滚 

} 

if(!$conn->query("update tb_zy set money=money+".$tob." where flag=mr"){ // 增 加 指定 账户 所 要 的 转账 金额 
S$conn->rollback(); /如 果 失 败 则 事务 回 滚 

S$conn->commit(); // 提 交 查 询 

Sconn->autocommit(true); /恢复 查询 自动 提交 

echo "<script>window location href-'index.php';</script>"; // 重 定向 到 首页 


首先 调用 mysqli 类 的 autocommit0 方 法 关闭 数据 库 的 自动 提交 ， 然 后 减少 A 账户 一 定数 量 的 金额 并 判断 查 
询 是 否 顺利 执行 ， 如 果 在 此 过 程 中 发 生意 外 ， 则 通过 调用 mysqli 类 的 rollback0 方 法 回 滚 ， 不 做 任何 处 理 ， 反 之 
为 B 账户 增加 相同 的 金额 。 最 后 通过 调用 mysqli 类 的 commit(0 方 法 提交 查询 ， 实 现 转账 。 


图 设计 过 程 
(1) 利用 MySQLi 扩展 技术 实现 与 MySQL 数据 库 的 连接 ， 代 码 如 下 : 


Sconn=new mysqli("localhost", "root","111","db_database09"); // 建 立 与 MySQL 数据 库 的 连接 

$conn->query("set names utf8"); // 设 置 数据 库 字符 集 编码 为 UTF-8 
(2) 查询 A 账户 与 B 账户 的 现 有 金额 并 在 页 面 中 显示 ， 代 码 如 下 : 

include_once("conn.php"): // 包 含 数据 库 连接 文件 conn.php 

$sql=$conn->query("select + from tb_zy where flag="mrsoft"); /查询 mrsoft 用 户 的 信息 

Sinfo=$sql->fetch array(MYSQLI ASSOC); 

$sqll=$conn->query("select * from tb_zy where flag="mr"); /查询 mr 用 户 的 信息 


Sinfo1-$sql1->fetch_array(MYSQLI ASSOC): 
(3) 实现 转账 。 该 部 分 的 关键 代码 已 经 在 关键 技术 中 给 出 ， 这 里 不 再 袭 述 。 


国 秘笈 心 法 


心 法 领悟 469: 使 用 MySQLi 扩展 库 管 理 MySQL 数据 库 事务 时 ， 需 要 关闭 事务 的 自动 提交 。 
默认 情况 下 使 用 MySQLi 扩展 库 管理 MySQL 数据 库 时 ， 事 务 是 自动 提交 的 ， 所 以 在 对 事务 管理 时 首先 需 
要 关闭 事务 的 自动 提交 ， 其 方法 如 下 : 


Smysqli->autocommit(false); 
从 上 述 代码 可 知 ， 通 过 调用 mysqli 类 的 autocommit0 方 法 ， 并 为 其 参数 指定 FALSE 值 即 可 关闭 事务 的 自动 
提交 。 同 理 ， 如 果 为 该 方法 的 参数 指定 TRUE 值 则 可 以 恢复 事务 的 自动 提交 功能 。 
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10.1 连接 数据 库 


SQL Server 是 微软 公司 开发 的 数据 库 产 品 。 随 着 SQL Server 2005 的 诞生 ， 越 来 越 多 的 企业 开始 使 用 SQL 
Server， 下 面 将 通过 具体 实例 讲解 PHP 连接 SQL Server 数据 库 的 方法 。 


TOE . 


SQL Server 数据 库 高 级 


趣味 指数 : 依依 依依 | 


实例 470 


力 实例 说 明 


本 实例 通过 ADO 方式 连接 SQL Server 数据 库 ， 运 行 本 实例 ， 如 果 出 现 如 图 10.1 所 示 的 用 户 信息 页 面 ， 说 
明 数 据 库 连 接 成 功 。 


图 10.1 ADO 方式 连接 SQL Server 数据 库 


力 关键 技术 
PHP 通过 预定 义 类 com 来 使 用 ADO 方法 操作 数据 库 ， 该 类 的 详细 说 明 如 下 : 


| 

参数 说 明 : 

module name: 被 请 求 组 件 的 名 字 或 class-id。 

server_name: DCOM 服务 器 的 名 字 。 

codepage: 指定 用 于 将 PHP 字符 串 转换 成 UNICODE 字符 串 的 代码 页 , 反之 亦 然 。 该 参数 的 取 值 有 有 CP_ACP、 
CP_ MACCP、 CP _ OEMCP、 CP_SYMBOL、 CP_THREAD ACP、 CP_UTF7 和 CP_UTFS8。 

本 实例 与 SQL Server 建立 连接 的 代码 如 下 : 


Sconn =new com("adodb.connection");: 
$connstr = "provider = sqloledb:data se 201006101638:uid=sa:pwd=:database=db_database10"; 
$conn -> open($connstr): 


图 设计 过 程 
(1) 在 SQL Server 中 创建 数据 库 及 数据 表 用 于 连接 测试 。 
(2) 连接 SQL Server 数据 库 ， 建 立 记录 集 ， 通 过 while 语句 完成 用 户 信息 的 输出 ， 代 码 如 下 : 


<?php 

if$_GET[d] = "1){ 
$sql = "select * from tb demo01"; 
Srs = new com("adodb.recordset"); 
Srs -> open($sql,$conn.1.1): 
ifsSrs -> eof || $rs -> bof){ 

echo " 暂 无 用 户 注册 信息 "; 

Jelse{ 


me 

<td align="center"> 用 户 名 </td> 

<td align="center"> 密 &nbsp:&nbsp: 码 <itd> 
<ltr> 


631 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


<?php 
while(!$rs -> eof){ 
> 
<t> 
<td bgcolor="#FFFFFF" align="center"><?php $fields = Srs -> fields(usemame):echo $fields -> value:?></td> 
<td bgcolor="#FFFFFF" align="center"><?php S$fields = Srs -> fields(pwd);echo $ficlds -> value:?></td> 
</lt> 
<?php 
Srs -> movenext; 
} 
} 
?> 
秘笈 心 法 


心 法 领悟 470: 什么 是 ADO。 

微软 的 ADODB 数据 库 驱 动 ActiveX Data Objects (ADO) ， 是 Microsoft 开放 数据 库 应 用 程序 的 数据 库 访 
问 技 术 。 它 被 设计 用 来 同 新 的 数据 访问 层 OLE DB Provider 一 起 协同 工作 ， 提 供 通用 数据 访问 〈Universal Date 
Access) 。OLE DB 是 一 个 低层 的 数据 访问 接口 ， 可 用 于 访问 各 种 数据 源 ， 包 括 传统 的 关系 型 数据 库 、 电 子 邮 件 
系统 及 自 定 义 的 商业 对 象 。ADO 技术 大 大 简化 了 OLE DB 的 操作 ， 因 为 ADO 封装 了 OLE DB 程序 中 使 用 的 大 
量 COM 接口 ， 所 以 ADO 是 一 种 高 层 的 访问 技术 。 


力 实例 说 明 


PHP 除了 可 以 通过 ADO 方式 建立 与 SQL Server 数据 库 的 连接 外 ,还 可 以 通过 其 预定 义 函数 mssql_ connect0 
与 SQL Server 建立 连接 ， 使 用 这 种 方式 建立 连接 与 使 用 函数 mysql_connect0 建 立 与 MySQL 数据库 的 连接 方法 
类 似 。 运 行 本 实例 ， 效 果 如 图 10.2 所 示 。 


图 10.2 mssql_connect0 函 数 连接 SQL Server 数据 库 


力 关键 技术 


使 用 PHP 连接 SQL Server， 需 要 开启 PHP 对 SQL Server 的 支持 。 方 法 是 打开 PHP 配置 文件 php.ini， 将 
extension=php_mssql.dll 前 的 “;” 注 释 去 掉 ， 然 后 重新 启动 Apache 服务 器 。 
(1) mssql . connect0 函 数 打开 一 个 MSSQL Server 连接 ， 返 回 一 个 连接 标识 ， 其 语法 如 下 : 
Tesource mssql_connect ( [string servemame [, string usemame [. string password]]] ): 
参数 说 明 : 
string servername: 主机 名 。 
string username: 用 户 名 。 
string password: 密码 。 
(2) mssql query0O 函 数 发 送 一 条 请 求 ， 返 回 一 个 结果 集 ， 其 语法 如 下 : 


mixed mssql_query ( string query [. resource link_identifier [, int batch_size]] ) 
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参数 说 明 : 
string query: SQL 语句 。 
link_identifier: 连接 标识 。 
(3) mssql fetch_row0 函 数 取得 一 行 数据 ， 保 存 于 数组 中 ， 其 语法 如 下 : 
array mssql fetch row ( resource result ) 
参数 说 明 : 
resource result: 结果 集 。 
本 实例 与 SQL Server 建立 连接 的 代码 如 下 : 


$conn = mssql connect("localhost","sa",”") or die ("Connect MySQL False"): 
mssql_select_db("db_database10",$conn): 


图 设计 过 程 
在 本 实例 中 ， 通 过 mssql_connect0 函 数 连接 SQL Server， 应 用 mssql_query0 函 数 执行 查询 语句 ， 应 用 
mssql_fetch rowO 函 数 和 while 语句 完成 用 户 信息 的 循环 输出 ， 其 关键 代码 如 下 : 


<?php 
$conn = mssql_connect ( "localhost", "sa", "" ) or die ( "Connect SQL Server False" ); /连接 SQL Server 服务 器 
mssql_select_db ( "db_database10", $conn ); /| 连接 db_database10 数据 库 
if($_GET [id] ='1) { 
> 
<?php 
if($rs = mssql_query("select * from tb_demo01"){ // 如 果 返 回 结果 集 
while($rst = mssql_fetch_row($rs){ /循环 输出 结果 集 
?> 
<tr> 
<td bgcolor="#FFFFFF" align="center"><?php echo $rst[0]:?></td> 
<td bgcolor="#FFFFFF" align="center"><?php echo $rst[1]:?></td> 
<lt> 
<?php 
jelsef 
echo "<script>alert( 数 据 表 存在 问题 );</script>"; 
} 
i 
?> 
国 秘笈 心 法 


心 法 领悟 471: 如 何 检测 PHP 是 否 支持 SQL Server 数据 库 。 
编写 脚本 文件 ， 输 入 如 下 代码 ; 
<?php 
echo phpinfo0; 
> 
经 下 浏览 器 运行 本 文件 ， 如 果 网 页 中 显示 mssql 内 容 ， 表 示 PHP 支持 SQL Server 数据 库 。 
如 果 用 户 使 用 的 SQL Server 数据 库 是 2000 版 本 ， 可 能 会 出 现 unable connect server:localhost 错误 ， 造 成 这 
种 错误 的 原因 一 般 分 为 两 种 情况 : 
(1) 代码 存在 错误 。 检 查 SQL Server 服务 管理 器 是 否 处 于 正在 运行 的 状态 。 
(2) 系统 可 能 缺少 ntwdblib.dll 文件 。 用 户 可 以 手动 下 载 ntwdblib.dll-2000.80.2039.0 文件 ， 将 此 文件 复制 
到 Apache\bin 文件 夹 和 php\bin 文件 夹 下 ,然后 重启 SQL Server 服务 器 和 Apache 服务 器 即 可 。 也 可 为 SQL Server 
打上 sp4 补丁 ， 然 后 重启 服务 器 。 


10.2 操作 数据 库 
SQL Server 数据 库 与 MySQL 数据 库 虽然 都 是 存储 信息 的 载体 ， 但 是 在 操作 方法 与 函数 上 略 有 不 同 。 本 节 
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将 具体 讲述 对 SQL Server 数据 库 的 相关 操作 。 


力 实例 说 明 


在 进行 网 站 开发 过 程 中 ， 经 常用 到 对 指定 时 间 段 的 信息 检索 ， 例 如， 检索 指定 时 间 段 内 有 哪些 PHP 类 图 书 
出 版 等 。 运 行 本 实例 ， 当 单 击 “ 信 息 检 索 ” 超 链接 时 ， 将 显示 2009 一 2010 年 明日 科技 编写 的 所 有 PHP 类 图 书 ， 
其 运行 效果 如 图 10.3 所 示 。 


《PRP 范 网 字 并》 人 民 地 电 出 版 社 


《PRP 实 成 字典》 清华 大 学 出 版 社 
《pqP 同 络 坞 程 》 杰 财 大 学 出 版 社 


图 10.3 通过 ADO 实现 指定 时 间 段 的 信息 检索 


力 关键 技术 


本 实例 通过 ADO 操作 SQL Server 数据 库 ， 执 行 指定 时 间 段 内 的 信息 查询 操作 ， 其 信息 检索 的 SQL 语句 代 
码 如 下 : 


$sql = "select id,bname.price.pub from tb_demo03 where date>="2009-01-01' and date<="2010-12-31"; 
图 设计 过 程 
创建 index.php 文件 , 首先 通过 ADO 连接 SQL Server 数据 库 , 然后 建立 记录 集 , 实现 用 户 信息 的 循环 输出 ， 


其 关键 代码 如 下 : 
<?php 
$conn = new com ( "adodb.connection" ); 
$connstr = "provider = sqloledb:data source=PC-201006101638:uid=sa:pwd=:database=db_database10"; //ADO 连接 数据 库 
$conn->open ( $connstr ); 
if($_GET [id] ="1") { 
$sql = "select id.bname.price.pub from tb_demo03 where date>=2009-01-01' and date<="2010-12-31"; 
S$rs = new com ( "adodb recordset" ); 
Srs->open ( $sql, Sconn ); 
if($rs->eof || $rs->bof) { 
echo "数据 库 暂 无 信息 ": 
Yelsef{ 
> 


<tr> 
<td align="center 吃 图 书 ID</td> 
<td align="eenter 必 图 书 名 称 </htd> 
<td align="center 必 图 书 价格 <ltd> 
<td align="center 吃 出 版 社 </td> 
<t> 


while (1 Srs->eof ) { 
?> 


<tr> 
<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8', Srs->ficlds (id )->value ): ?></td> 
<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8', Srs->ficlds ( bname )->value ): ?></td> 
<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( "gbk', ‘utf-8'. $rs->ficlds ( price )->value ): ?></td> 
<td align="center” bgcolor="#FFFFFF"><?php echo iconv ( "gbk', ‘utf-8'. $rs->fields (pub )->value ): ?></td> 
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心 法 领悟 472， 解决 页 面 乱码 问题 。 


由 于 在 SQL Server 中 使 用 的 编码 格式 是 GBK, 而 页 面 中 的 编码 格式 为 UFT-8, 所 以 需 使 用 转 码 函数 iconv0 
对 输出 结果 进行 转 码 ， 否 则 将 输出 乱码 。 


实例 473 


力 实例 说 明 


在 实际 开发 中 ， 很 多 程序 都 会 涉及 对 信息 的 检索 。 运 行 本 实例 ， 输 入 商品 ID， 单 击 “ 检 索 ” 按 钮 ， 将 查找 
出 匹配 的 商品 信息 并 且 对 商品 名 称 描 红 显 示 ， 运 行 结果 如 图 10.4 所 示 。 


通过 ADO 方 式 实现 指定 时 间 段 的 信息 检索 
0 


ee EB 


而 ID 商品 训 称 两 而 从 检 商品 类 型 
了 液晶 电视 S00 元 系 也 


10.4 商品 信息 的 检索 


图 关键 技术 


本 实例 通过 mssql_connectO 函 数 连接 SQL Server 服务 器 ， 通 过 mssql_ select_ db0 函 数 连接 db_database10 数 
据 库 ， 通 过 mssql_query0 函 数 执行 查询 语句 ， 通 过 mssql_fetch row0 函 数 获取 查询 结果 中 的 数据 ， 其 关键 代码 


如 下 : 
<?php 
$conn = mssql_connect ( "localhost", "sa", "" ) or die ( "Connect SQL Server False" ); /连接 数据 库 服务 器 
mssql_select_db ( "db_database10", $conn ) or die ( "Connect Database False" ); // 连 接 数据 库 
if($_POST [sub]) { // 判 断 提交 按钮 是 否 为 空 
让 ($_POST [text] 一 "||$_POST [texd] 一 "输入 商品 ID") { // 如 果 提交 ID 值 为 空 ， 则 给 出 提示 信息 
echo "<script>alert( 请 输入 查询 关键 字 ');</script>"; 
}else{ 
S$rs = mssql_query ( "select + from tb_demo04 where id=" . $_POST [text] ); // 执 行 查询 语句 
> 
看 设计 过 程 
(1) 在 index.php 文件 中 首先 创建 form 表单 ， 将 商品 的 ID 值 提交 到 本 页 ， 其 代码 如 下 : 
<form action="" method="post"> 


<input class="one” type="rext” name="text” value=" 遂 入 咬 咒 1D" size="15" onfocus="this.value="" /> 
<input class="fwo" type="submit” name="sub" value="@nbsp;" (> 
</form> 


(2) 在 index.php 文件 中 ， 通 过 mssql_connect0 函 数 连接 SQL Server， 根 据 form 表单 中 提交 的 ID 值 执行 


查询 语句 并 循环 输出 查询 结果 ， 代 码 如 下 : 


<Iphp 
Sconn = mssql_connect ( "localhost", "sa". "" ) or die ( "Connect SQL Server False" ): 
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mssql_select_db ( "db_database10", $conn ) or die ( "Connect Database False" ): 
if($_POST [sub)) { 
证 ($ 1 ll 11$_ POST [tex 一 "输入 商品 ID") { 
o "<script>alert(' 请 输入 查询 关键 字 ):</script>"; 
ee 
Srs = mssql query ("select * from tb demo04 where id=" .$ POST [text]); 
bo 


<t> 
<td align="cenler> 商 品 ID</td> 
<tdalign="eenter 必 商品 名 称 <jtd> 
<td align="center > 商品 价格 </td> 
<td align="center > 商品 类 型 </td> 
</tr> 


Srst =mssql fetch row (Srs ); 


<tr> 
<td align="center” bgcolor="#FFFFFF"><?php ccho Srst [0]; 2></td> 
<td ><font size="+1" color="#FF0000’><b><?php echo iconv (‘gbk', ‘utf-8', Srst [1] );?></b></font></td> 
<td bgcolor="HFFFFFF" align="center "><?php echo iconv ( "gbk', utf-8'. Srst [2] ); ?></td> 
<td bgcolor="HFFFFFF" align="center"><?php ccho iconv('gbk','utf-S',$rst[3]):?></td> 


图 秘笈 心 法 


心 法 领悟 473: 判断 连接 SQL Server 数据 库 是 否 成 功 的 方法 。 
判断 连接 数据 库 是 否 成 功 的 方法 有 很 多 。 例 如 ， 可 以 应 用 让 条 件 语句 对 函数 进行 判断 。 笔 者 喜欢 用 or die0 
方法 实现 对 目标 函数 的 检测 ， 其 最 大 的 优点 是 书写 简单 、 逻 辑 清晰 、 代 码 量 小 。 


力 实例 说 明 


在 使 用 SQL Server 数据 库 时 ， 很 多 时 候 需 要 获取 指定 的 第 n 条 数据 信息 。 用 MySQL 数据 库 实现 此 功能 非 
常 简单 。 那 么 如 何在 SQL Server 数据 库 中 实现 相同 的 功能 呢 ? 下 面 就 来 向 读者 讲解 实现 此 功能 的 具体 方法 。 运 
行 本 实例 ， 在 图 10.5 所 示 的 文本 框 中 输入 指定 的 ID 值 ， 单 击 “ 确 定 ”按钮 ， 将 输出 如 图 10.6 所 示 的 内 容 。 


高 级 | 
趣味 指数; 砍 庚 让 


请 术 入 娄 于 


1 《PRP 开 发 括 波 宝典》 
2 《PP 标注 教程 

3 《Pf 网络 编程 室 训 》 
4 

5 


PHP 范例 宝 其 》 
《PHP 范 仙 手册 》 


131 0: 00 
2010/ 和 有 /3 0: 00 


图 10.5 数据 库 信息 图 10.6 获取 指定 位 置 的 图 书信 息 


看 关键 技术 
本 实例 主要 应 用 mssql_data_seek0 〇 函数 。mssql_data_seek0 〇 函数 将 指定 的 结果 标识 所 关联 的 SQL Server 结果 
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内 部 的 行 指针 移动 到 指定 的 行 号 。 如 果 成 功 则 返回 TRUE， 否 则 返回 FALSE， 其 语法 如 下 : 


bool mssql data_seek( resource result identifier, int row_number ) 
参数 说 明 : 
result_identifier: 返回 类 型 为 resource 的 结果 集 ， 该 结果 集 从 mssql_ query0 函 数 的 调用 中 得 到 。 
row_number: 想 要 设 定 的 新 的 结果 集 指针 行 数 。 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 通 过 mssql 函数 库 连 接 SQL Server 数据 库 。 
(2) 新 建 index.php 文件 ， 首 先 创建 form 表单 ， 提 交 定 位 查询 所 使 用 的 数字 。 然 后 对 表单 中 提交 的 定位 查 
询 数据 进行 判断 ， 如 果 提 交 的 值 正确 ， 则 应 用 mssql _data_seek(0 函 数 定位 指针 位 置 ， 通 过 mysql_fetch row0 函 数 
获取 查询 结果 中 的 记录 集 ; 否则 给 出 提示 信息 ， 并 且 通 过 while 语句 和 mssql_fetch_row0 函 数 循环 输出 数据 库 中 
的 所 有 记录 ， 其 关键 代码 如 下 : 


这 ($_POST [text] 一 "||$_POST [text] 一 "请 输入 数字 ") { 
echo "<script>alert( 请 在 文本 框 中 输入 信息 ”);</script>"; 
}else { 
if(! preg_match (Ad $_POST [text] )) { 


echo "<script>alert(' 请 输入 数字 ')</script>"; 
} else { 
if(@mssql data seek (Srs,$ POST [text]) { 
ss= mssql_feteh_row ( $rs ); 
<tr> 
<td style="background: HFFFFFF"><?php echo iconv (‘gbk’, utf-8', sts [0] )?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8', Sts [1] )?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8', $ts [2] )?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( 'gbk', ‘utf-8', $ts [3] )?></td> 
<ltr> 
?php 
} else { 
echo "<script>alert( 输 入 无 效 数据 或 超出 范围 ):</script>"; 
} 
} 
. 
力 秘笈 心 法 


心 法 领悟 474: 使 用 mssql_data_seek0 函 数 的 注意 事项 。 
使 用 此 函数 时 要 注意 ， 参 数 row_number 是 从 0 开始 的 ， 所 以 若 在 本 实例 文本 框 中 输入 数字 1， 获 取 的 是 数 
据 库 中 的 第 2 条 数据 。 
高 级 


图 实例 说 明 


在 PHP 操作 MySQL 数据 库 中 ， 获 取 数 据 字 段 信息 使 用 mysql_ fetch_field 0 函数 ， 而 在 mssql 函数 库 中 操作 
SQL Server 数据 库 获取 数据 字段 信息 使 用 mssql_fetch_field0 函 数 。 在 本 实例 中 ， 通 过 mssql fetch_field0 函 数 获 
取 数 据 表 中 指定 字段 的 信息 ， 在 图 10.7 所 示 的 文本 框 中 输入 一 个 数字 值 ， 单 击 “ 确 定 ” 按 钮 ， 将 输出 如 图 10.8 
所 示 的 内 容 。 
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天 得 歼 二 申办 定 的 字 肥 有 区 
CC 


请 畏 入 级 字 


《PHP 开 发 实战 宝 积 } 1 7 
证 《php 标准 教程 》 19 元 ‘00 | 
3 《PHP 网 引 妨 程 主 岗 } J; 雹 / 
4 《PHP 范例 宝典 9 元 2000 入 月 /3 mo 
了 《PHP 范例 竹山》 6 元 DOORAINH 00 | date dete datetine | 4 ] 
图 10.7 显示 数据 库 中 的 数据 图 10.8 ”获取 字段 信息 


mssql_fetch field0 函 数 ， 从 结果 集中 获取 列 信息 并 作为 对 象 返回 ， 其 语法 如 下 : 


object mssql_fetch_ficld ( resource result [, int field_offset] ) 


mssql_fetch_field0 函 数 返 回 的 对 象 的 属性 如 表 10.1 所 示 。 
表 10.1 mssql_fetch_field() 函 数 返回 的 对 象 的 属性 


属 性 说 明 
name 列 名 
column source 具体 的 列 名 
max length 该 列 最 大 长 度 
numeric 1， 如 果 该 列 是 numeric 
ype 该 列 的 类 型 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 通 过 mssql 函数 库 连 接 SQL Server 数据 库 ， 其 代码 如 下 : 


<?php 

$conn = mssql_connect("localhost","sa","") or die ("连接 SQL Server 时 发 生 错 误 "); 
mssql_select_db("db_database10",$conn) or die ("连接 数据 库 发 生 错 误 "); 

> 


(2) 新 建 ndex.php 文件 ， 首 先 创建 form 表单 ， 提 交 定 位 查询 所 使 用 的 数字 。 然 后 对 表单 中 提交 的 定位 查 
询 数据 进行 判断 ， 判 断 其 值 是 否 为 空 、 提 交 的 数据 是 否 为 数字 、 提 交 的 值 是 否 超出 范围 ， 如 果 完 全 符合 条 件 ， 
则 应 用 mssql_fetch_field0 函 数 获取 表单 中 指定 字段 的 数据 ; 如 果 判 断 结果 不 符合 要 求 ， 则 给 出 相应 的 提示 信息 ， 
并 且 循 环 输出 数据 表 中 所 有 的 数据 ， 其 关键 代码 如 下 : 
< 
Es once ("conn.php"); 
S$rs = mssql_query ( "select * from tb_demo10" ); 
if(isset ( $_POST [sub] )) { 
并 ($_POST [text] 一 "||$_POST [text] 一 "请 输入 数字 ") { 
echo "<script>alert( 请 在 文本 框 中 输入 信息 ”);</script>"; 
else 
je preg match ("/\d/".$ POST ftext])) { 
echo "<seript>alert( 请 输入 数字 ')</script>"; 
else 
ee POST ftext] >3) { 
echo "<script>alert( 超 出 取 值 范围 ):</script>": 
clse 
2 人 = @mssql_fetch ficld ( $rs. $_POST [text] ): 
} 


= 
<table bgcolor="#DEED88" width="580px"> 


<td class="0">name</td> 
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<td class="0'>eolumn_source</td> 
<td class="0'>type</td> 
<td class="0 ">max_ length</td> 

<hr> 

<t> 
<td style="background: HFFFFFF"><?php echo iconv (‘gbk, ‘utf-8", $ts->name )?></td> 


}else{ 
?> 


心 法 领悟 475， 使 用 mssql_fetch_field0 函 数 的 注意 事项 。 
mssql_fetch field0 函 数 可 以 用 来 从 某 个 查询 结果 中 获取 字段 的 信息 。 如 果 没有 指定 字段 偏 移 量 ， 则 下 一 个 
尚未 被 mssql_fetch_field0) 函 数 获取 的 字段 将 被 提取 。 


me() 函 数 获 取 字 段 名 称 


实例 476 Daten 丰 妇 页 


实例 说 明 


实例 475 中 通过 mssql_fetch_field0 函 数 返回 对 象 的 name 属性 获取 字段 的 名 称 , 下 面 将 介绍 在 mssql 函数 库 
中 专门 用 来 获取 字段 名 称 的 方法 。 运 行 本 实例 ， 在 文本 框 中 输入 一 个 有 效 的 字段 值 ， 单 击 “确定 ”按钮 ， 将 输 
出 如 图 10.9 所 示 的 页 面 。 


《pHp 开 友 实 路 宝典》 
《PHP 标准 教程 } 
《PhP 网 络 编程 宇 奥 》 
范例 室 抒 } 
| 世人 了 二》 
| 并 据 东 字 联 记 称 为 price 


10.9 利用 mssql_field_name0 函 数 获 取 字 段 名 称 


力 关键 技术 


本 实例 主要 应 用 mssql_field 次 下 之 入 的 名 称 , 其 语法 如 下 : 


string mssql field_name ( resource result, int ficld_ index 
该 函数 返回 指定 字段 索引 的 字段 名 。 做 result 必须 是 一 个 合法 的 结果 标识 符 ， 参 数 field_index 是 该 字段 
的 数字 偏 移 量 。 


图 设计 过 程 


(1) 新 建 conn.php 文件 ， 通 过 mssql 函数 库 连 接 SQL Server 数据 库 。 
(2) 新 建 index.php 文件 ， 首 先 创建 form 表单 ， 提 交 定 位 查询 所 使 用 的 数字 。 然 后 执行 查询 语句 ， 并 通过 
while 语句 和 mssql fetch row0 函数 循环 输出 查询 结果 集中 的 数据 。 最 后 获取 表单 提交 的 数据 ， 应 用 
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mssql field_ name() 函 数 获取 指定 字段 的 名 称 ， 其 代码 如 下 : 


<?php 


if(isset ($_POST [sub] ) { 
站 ($_POST [te] 一 "||$_POST [te] 一 "输入 数字 ") { 
echo "<script>alert(' 请 在 文本 框 中 输入 内 容 );</script>"; 
else 
: 人 ("Nd",$_ POST [te]) { 
if($_POST [te] > 4) { 
echo "<script>alert( 输 入 的 数字 超出 范围 ):</script>"; 


Jelse{ 
Srss = mssql ficld_name ( $rs, $_POST [te] ): 
} 
yelse{ 


echo "<script>alert( 您 输入 的 不 是 数字 ):</script>"; 
} 
?> 
<a> 
<td bgcolor="#FFFFFF"> 数 据 表 字段 名 称 为 </td> 
<td bgecolor="#FFFFFF" style="color: #FF0000"><?php echo $rss:?></td> 
<lt> 


?> 


图 秘笈 心 法 
心 法 领悟 476: 使 用 mssql_field_name(0) 函 数 的 注意 事项 。 


在 使 用 此 函数 时 ， 参 数 field_index 从 0 开始 。 例 如 ， 第 3 个 字段 的 索引 值 其 实 是 2， 第 4 个 字段 的 索引 值 
是 3， 依 此 类 推 。 


和 中 。 | 
趣味 指数 : 依依 请 弃 | 
图 实例 说 明 


从 结果 集中 获取 数据 的 方法 有 很 多 ， 本 实例 主要 讲解 利用 数据 对 象 输出 结果 集中 的 数据 。 运 行 本 实例 ， 
效果 如 图 10.10 所 示 。 


0HP 标 渣 鞭 程 》 
《pHp 网 给 编程 宝 些 ] 

《PP 葬 何 宝典 》 

《PRP 范 何 手 册 》 


10.10 通过 结果 集 对 象 输出 数据 


图 关键 技术 
mssql fetch_object0 函 数 从 结果 集中 获取 一 行 作为 对 象 ， 如 果 没 有 更 多 行 则 返回 FALSE， 其 语法 如 下 : 


object mssql_fetch_object ( resource result ) 
该 函数 和 mssql_fetch_array0 函 数 类 似 ， 只 是 返回 一 个 对 象 而 不 是 数组 ， 即 只 能 通过 字段 名 来 访问 数据 ， 而 
不 是 偏 移 量 数字 是 合法 的 属性 名 ) 。 
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图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 


(2) 创建 index.php 文件 ， 包 含 数 据 库 连接 文件 ， 通 过 mssql_ query0 函 数 执行 查询 操作 ， 通 过 while 语句 
和 mssql_fetch_object0 函 数 循环 输出 查询 结果 集中 的 数据 ， 其 代码 如 下 : 


<Iphp 
while ( $rst = mssql fetch object (S$rs)){ 
?> 


<t> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk", "utf-8", Srst->id ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk", "utf-8", Srst->bname ): ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk", "utf-8", Srst->price ):?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( "gbk"."utf-8",Srst->date):?></td> 

<l> 

php 
} 


We 


国 秘笈 心 法 


心 法 领悟 477: 使 用 mssql_fetch_object0 函 数 的 注意 事项 。 


高 级 | 
实例 478 起 味 指数 : 页 机 页 
国 实例 说 明 


实例 477 中 讲解 了 通过 结果 集 对 象 输出 数据 ， 下 面 将 通过 另外 一 个 函数 将 结果 集 以 数组 的 形式 输出 。 运 行 
本 实例 ， 结 果 如 图 10.11 所 示 。 


Se 


Pe 于 
Tsonnnns 


《PHP 开 发 拓 战 字典 
《PHP 标 准 教程 》 
《PHP 网 站 编程 宝典 》 
《PHP 范 例 宝 奥 》 
《PHP 苑 例 手册 》 


10.11 通过 结果 集 数 组 输出 数据 


图 关键 技术 


本 实例 主要 应 用 mssql_fetch_assoc0 函 数 ， 从 结果 集中 获取 一 行 作 为 关联 数组 。 如 果 没 有 更 多 行 则 返回 
FALSE， 其 语法 如 下 : 


array mssql_fetch assoc ( resource result id ) 


参数 result id 为 指定 的 结果 集 。 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 


(2) 创建 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 通 过 mssql query0 函 数 执行 查询 操作 ， 通 过 while 语句 
和 mssql_fetch_assoc0 函 数 循 环 输出 查询 结果 集中 的 数据 ， 其 代码 如 下 : 


Ca 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


include_once ("conn.php"): 
Srs =mssql_query ( "select + from tb_demo10" ); 


<table width="580px" bgcolor="#FC8C7E"> 
<tr> 


<td style="color: #FFFFFF; text-align: center"> 图 书 ID</td> 
<td style="color: #FFFFF; text-align: center"> 图 书 名 称 </td> 
<td style="color: #FFFFFF; text-align: center"> 图 书 价格 </td> 
<td style="color: 二 FFFFF; text-align: center> 出 版 日 期 <td> 
<lo> 


while ( Srst= mssql fetch assoc ( $rs )){ 
?> 


<tr> 


| hk, ‘utf8, Sta 2><hd> 
td style="background: "Si 


Srst [price] ); 2></td> 
Ed #FFFFFF"><?php echo iconv ( 'gbk' 二 人 ?><ltd> 


?> 


国 秘笈 心 法 


心 法 领悟 478: 使 用 mssql_fetch_assoc0 函 数 的 注意 事项 。 
由 于 该 函数 返回 的 是 一 个 关联 数组 ， 所 以 在 获取 数组 中 的 元 素 时 必须 使 用 字段 名 称 作 为 数组 的 索引 ， 同 时 


还 要 注意 ， 其 数组 的 索引 是 区 分 大 小 写 的 。 


实例 479 


图 实例 说 明 


如 果 用 户 只 想 查看 用 户 名 或 者 只 想 查看 单一 的 一 项 数据 ， 程 序 员 就 没有 必要 在 与 数据 库 的 交互 中 取得 一 行 


数据 ， 只 需要 从 数据 库 中 取得 单一 字段 信息 即 可 。 本 实例 通过 函数 mssql_result0 实 现 获 取 结果 数据 ， 运 行 结果 


如 图 10.12 所 示 。 

HP 开 发 实 歧 宝 鼻 》 

《PHP 标 准 教 程 》 

{PP 同 给 坊 程 主 共 》 

《48 区 介 宇 典 》 

《p99 区 说 手 册 》 

图 10.12 返回 结果 集中 的 单元 内 容 
图 关键 技术 
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本 实例 的 关键 点 是 如 何 运 用 mssql resultO 函 数 返回 结果 集中 的 单元 内 容 ， 其 语法 如 下 : 


string mssql_result ( resource result int row. mixed ficld ) 
参数 说 明 : 
resource result: 结果 集 。 
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introw: 列 数 。 
mixed field: 指定 字段 。 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 
(2) 创建 index.php 文件 ， 首 先 创建 form 表单 ， 提 交 指定 要 查询 的 列 数 和 字段 名 称 。 然 后 包含 数据 库 连 接 
文件 , 通过 mssql_query0 函 数 执 行 查询 操作 ,通过 while 语句 和 mssql _fetch row0 函 数 循 环 输出 查询 结果 集中 的 
数据 。 接 着 对 form 表单 中 提交 的 数据 进行 判断 ， 如 果 符合 要 求 则 运用 mssql_result0 函 数 获取 结果 集中 指定 单元 
的 内 容 ， 其 关键 代码 如 下 : 
<php 
让 (isset($ POST [sub] ){ 


Stext =$_ POST [te]; 
$sclect =$_ POST [select]; 


计 ($_POST [te] 一 "||$_POST [te] 一 "输入 数字 ") { // 判 断 输入 的 值 是 否 为 空 
echo "<script>alert( 文 本 框 不 能 为 空 )</script>"; 
yelse { 
if (preg_match ( "/\d/", $text )) { // 判 断 输入 的 值 是 否 为 数字 
if ($text < 5){ 
Srst = mssql_result ( $rs, $text, $select ); 1/ 获取 指定 单元 的 内 容 
echo iconv ( ‘gbk', ‘utf-8", Srst ); /输出 指定 单元 的 内 容 
j else{ 
echo "<script>alert( 文 本 框 超出 取 值 范围 );</script>"; 
} 
}else{ 
echo "<script>alert(' 文 本 框 输入 的 不 是 数字 ');</script>"; 
} 
ji 
} 
力 秘笈 心 法 


心 法 领悟 479， 使 用 mssql_result0 函 数 的 注意 事项 。 
在 使 用 该 函数 的 int rows 参数 时 要 注意 下 标 是 以 0 开始 的 , 如 在 页 面 中 输入 数字 2, 其 实 是 表示 第 1 个 数据 单元 。 


tna oi 
sn | EEA ee 
力 实例 说 明 


在 创建 数据 表 时 ， 需 要 定义 字段 的 最 大 长 度 ， 如 果 插入 的 数据 信息 超过 这 个 最 大 长 度 ， 字 段 就 不 能 完整 地 
输出 。 运 行 本 实例 ， 通 过 函数 自动 获取 字段 信息 的 长 度 ， 结 果 如 图 10.13 所 示 。 


字段 长 度 为 20 


四 
1 《PHP 开发 实 态 宝 才 》 
2 《PHP 标准 技 程 》 
3 《ph? 网 站 坊 径 宝 自 》 
4 《PHP 范 合 宝典 》 
5 《PHP 范例 手册 》 


2010/ 和 有 /3 O00 


图 10.13 返回 指定 字段 的 长 度 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


图 关键 技术 
获取 指定 字段 的 长 度 应 用 的 是 mssql_field_length0 函 数 ， 其 语法 如 下 : 


int mssql_field length ( resource result, int ficld_offset ) 
参数 说 明 : 

resource result: 结果 集 。 

int field_offset， 字段 数 。 


图 设计 过 程 

(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 

(2) 在 index.php 文件 中 创建 form 表单 ， 提 交 指 定 要 查询 的 字段 值 并 且 将 数据 提交 到 本 页 。 

(3) 在 index.php 文件 中 包含 数据 库 连 接 文件 ， 执 行 查询 语句 完成 数据 表 中 数据 的 循环 输出 ， 并 对 表单 中 
提交 的 值 进行 判断 ， 如 果 符 合 要 求 ， 则 应 用 mssql_field_length0 函 数 获取 表单 提交 的 字段 的 长 度 值 并 且 输 出 ,其 


关键 代码 如 下 : 


<?php 
include_once ("conn.php"); 
S$rs = mssql._query ( "select * from tb_demo10" ); 
和 


<table width="580px" bgcolor="#FEF1BA"> 
<tr> 
<td style="color: #FFFFFF: text-align: center"> 图 书 ID</td> 
<td style="color: #FFFFFF; text-align: center"> 图 书 名 称 </td> 
<td style="color: 二 FFFFF; text-align: center"> 图 书 价格 </td> 
<td style="color: #EFFFFF; text-align: center"> 出 版 日 期 <td> 
<la> 


<?php 
if 人 isset($_ POST [sub] ) { 
Srss = mssql_ficld_length ( Srs, $_POST [select] ); 
echo "<font size=+l' color-red> 字 段 长 度 为 " . Srss . "</font>"; 
} 
while ( $rst= mssql_fetch row ( $rs )) { 
> 


<tr> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8', Srst [0] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk’, utf-8', Srst [1] ): 2></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk', utf-8', Srst [2] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8', Srst 3] ); ?></td> 


<?php 
} 


> 


国 秘笈 心 法 


心 法 领悟 480: 获取 数据 表 中 指定 字段 的 类 型 。 
在 mssql 函数 库 中 ， 不 但 可 以 获取 到 数据 表 中 指定 字段 的 名 称 、 长 度 、 定 位 指针 位 置 ， 而 且 可 以 获取 到 字 
段 的 类 型 ， 其 应 用 的 是 mssql field typeO 函 数 。 


rr ed 


力 实例 说 明 
通过 上 面 的 实例 ， 相 信 读 者 已 经 掌握 了 如 何 利用 函数 获取 字段 的 长 度 。 下 面 将 讲解 如 何 利用 函数 获取 指定 
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字段 的 字段 类 型 。 运 行 本 实例 ， 如 图 10.14 所 示 。 


利用 二 至 抬 @ 放 定 字 周 的 类 型 


字段 类 型 为 char 


图 日 卫生 a 
《PHF 开 发 实战 宝典 》 5 2010/ 作 月 /3 
《PHP 标 准 教程 》 2 2010/ 八 月 /31 
《PRP 网 络 编程 宝典 》 元 2010/ 八 月 /3; 
《PRP 范例 宝典 》 
《PRF 范 出 手册 》 E 2010/ 入 有 /3 


图 10.14 返回 指定 字段 的 类 型 


力 关键 技术 
本 实例 主要 应 用 mssql_field_type0 函 数 获取 结果 集中 指定 字段 的 类 型 ， 其 语法 如 下 : 


I 
参数 说 明 : 
resource result: 结果 集 。 


int offset;， 字段 数 。 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 SQL Server 数据 库 。 
(2) 在 index.php 文件 中 创建 form 表单 ， 提 交 指 定 要 查询 的 字段 值 并 且 将 数据 提交 到 本 页 ， 其 代码 如 下 : 


<form action="" method="post"> 
‘<select name="select"> 
<option value="0">ID 字段 </option> 
<option value="1"> 名 称 字段 </option> 
<option value="2"> 价 格 字段 </option> 
<option value="3"> 日 期 字段 </option> 
</select> 
<input type="submit" name="sub" value="" class="two" /> 
</form> 


(3) 在 index.php 文件 中 ， 包 含 数据 库 连接 文件 ， 执 行 查询 语句 完成 数据 表 中 数据 的 循环 输出 ， 并 对 表单 
中 提交 的 值 进行 判断 ， 如 果 符 合 要 求 ， 则 应 用 mssql_field_type 0 函数 获取 表单 提交 字段 的 类 型 值 并 且 输 出 ， 其 


关键 代码 如 下 : 
<?php 


include_once ("conn.php"); 
Srs = mssql_query ( "select * from tb_demo10" ); 
> 


< 
让 (isset($_ POST [sub] ) { 

Srss =mssql field_type ( $rs, $_POST [select] ): 

echo "<font size='+1' color='red> 字 段 类 型 为 " . Srss . "</font>"; 


} 
while ( Srst= mssql fetch row (Srs)){ 
> 


<t> 
<td style="background: #FFFFFF"><?php echo iconv (gbk. ‘utf-8', Srst [0]): ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk, ‘utf-8', Srst [11): ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( 'gbk'. ‘utf-8', Srst [2] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( 'gbk, ‘utf-8', Srst [3] ); ?></td> 


645 


PHP 开发 实例 大 全 《基础 卷 ) 


心 法 领悟 481: SQL Server 数据 库 中 的 字段 类 型 。 


SQL Server 数据 库 中 的 数据 类 型 与 MySQL 数据 库 中 的 数据 类 型 有 所 不 同 ，SQL Server 中 的 字段 类 型 包括 
int、real、string、blob 、date 等 。 


高 级 | 


趣味 指数 : 依 请 请 坪 | 


实例 482 


力 实例 说 明 


在 SQL Server 数据 库 中 ， 取 得 结果 集中 的 字段 数目 其 实 与 操作 MySQL 数据 库 大 同 小 异 。 下 面 就 来 讲述 如 
何在 SQL Server 数据 库 中 取得 结果 集中 的 字段 数目 ， 运 行 结果 如 图 10.15 所 示 。 


NS 有 


当前 数据 表 字 级 臻 日 为 4 


《PHP 开 发 实 成 宝典 》 

《PAP 标准 教程 

《PKP 同 络 编程 空 典 》 

《PHP 范 例 宝典 》 

《PHP 范 例 手册 》 468 元 2010/ 八 月 /1 0: 00 


10.15 ”获取 结果 集 的 字段 数目 


力 关键 技术 
获取 结果 集 的 字段 数目 主要 应 用 mssql_num_fields0 函 数 ， 其 语法 如 下 ; 


int mssql_num fields( resource result ) 


参数 resource result 指 结果 集 。 
看 设计 过 程 


(1) 新 建 conn.php 文件 ， 通 过 mssql_connect() 函 数 连接 SQL Server 数据 库 服 务 器 ， 然 后 通过 mssql_ 
select_db0 〇 函数 连接 db_database10 数据 库 ， 其 代码 如 下 : 
< 
=mssql_connect("localhost","sa","") or die ("连接 SQL Server 时 发 生 错误 
mssql_select_db("db_database10",$conn) or die ("连接 数据 库 发 生 错 误 "); 
> 


(2) 创建 index.php 脚本 文件 ， 包 含 数据 库 连 接 文件 ， 通 过 mssql_query0 函 数 执行 查询 语句 ， 应 用 
mssql_num fields() 函 数 获取 查询 结果 集中 总 的 字段 数 , 并 且 通 过 while 语句 和 mssql_fetch_row0 函 数 完成 查询 结 
果 集 中 数据 的 循环 输出 ， 代 码 如 下 : 

<?php 


include_once ("conn.php"); 
Srs = mssql_query ( "select * from tb_demo10" ): 
if($_GET[id]—D){ 

Srss =mssql num ficlds ( Srs ); 

echo "<font size='+1' color='red> 当 前 数据 表 字段 数目 为 " . Srss . "</font>"; 
} 
> 

<table width="580px" bgcolor="#CCES87"> 

<tr> 
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<td style="color: #FFFFFF:; text-align: center"> 图 书 ID</td> 

<td style="color: 考 FFFFF: text-align: center"> 图 书 名 称 </td> 

<td style="color: 二 FFFFF: text-align: center"> 图 书 价格 </td> 

<td style="color: 证 FFFFF; text-align: center"> 出 版 日 期 </td> 
<t> 


<?php 
while ( Srst= mssql fetch row (S$rs)){ 
> 


<tr> 
<td style= background: #FFFFFF"><?php echo iconv ('gbk, ‘utf-8", Srst [0] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( 'gbk', ‘utf-8', Srst [1] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( gbk' ‘utf-8", Srst [2] ); ?></td> 
<td style="background: #FFFFFF"><?php echo iconv ( ‘gbk, ‘utf-8', Srst [3] ); ?></td> 
<t> 
sphp 
?> 


心 法 领悟 482: 扩展 知识 。 
与 mssql num fields(0) 函 数 格式 类 似 的 mssql_ num rows0) 函 数 ， 可 用 于 获取 数据 表 中 结果 集 的 记录 数 。 


高 级 


实例 483 趣味 指数 : 袜 食 食 伍 


实例 说 明 


在 实例 482 的 秘笈 心 法 中 笔者 已 经 揭晓 ， 获 取 数据 表 中 数据 记录 数 应 用 的 是 mssql_num rows0 函 数 。 下 面 
将 通过 实例 向 读者 讲解 此 函数 的 具体 应 用 。 运 行 本 实例 ， 效 果 如 图 10.16 所 示 。 


| 《PAP 开发 实战 宝典》 元 2010/ 八 月 /31 0: 00 


| 《PP 标准 教程》 元 2010/ 八 月 1731 000 
《PHP 网络 蝙 吉 宝典 》 了 玩 20101 八 月 /31 0: 00 

元 20107 人 入 月 /31 0: 00 
20107 作 月 /31 0: 00 


10.16 ”获取 数据 表 中 数据 的 记录 数 


力 关键 技术 
本 实例 主要 应 用 mssql_num_rows0 函 数 实现 获取 数据 表 中 数据 的 记录 数 ， 该 函数 的 语法 如 下 : 


int mssql_ num rows (resource result ) 


参数 result 为 查询 结果 集 。 
图 设计 过 程 

创建 index.php 脚本 文件 ， 包 含 数据 库 连 接 类 ， 完 成 与 db_database10 数据 库 的 连接 ， 循 环 输出 数据 表 中 的 
数据 ， 当 单 击 “获取 总 数量 ”按钮 时 ， 输 出 数据 表 中 总 的 记录 数 ， 代 码 如 下 : 

[en include_once("conn.php"); // 包 含 数据 库 连接 文件 


Srs = mssql_ query("select * from tb_demo10"): 
> 


PHP 开发 实例 大 全 (基础 卷 ) 


<?php 
‘while($rst = mssql fetch row($rs)){ /循环 输出 


<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8'.$rst[0D):?></td> 
<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8'.$rst[1]):?></td> 
<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8'.$rst[2]):?></td> 
<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8',$rst[3]):?></td> 


} 
if($_GET[id] =— D{ // 当 按钮 被 单 击 
Srss = mssql_num rows($rs); /返回 结果 


bgeolor="#FFFFFF"> 数 据 表 数 据 </td><td bgeolor="#FFFFFF"> 信 息 数量 为 <ltd><td bgcolor="#FFFFFF"><?php echo Srss:?><ltd><td 

‘bgcolor="#FFFFFF"></td></tr> 

<?php 

三 } 

由 于 SQL Server 数据 库 中 使 用 的 是 GBK 编码 格式 ， 而 本 实例 的 页 面 应 用 的 是 UTF-8 编码 ， 所 以 在 输出 数 
据 库 中 的 数据 时 需要 应 用 iconv0 转 码 函 数 对 数据 库 的 编码 格式 进行 转换 ， 否 则 将 输出 乱码 。 


国 秘笈 心 ; 


心 法 领悟 483:; 使 用 mssql_ num rows0 函 数 的 注意 事项 。 
mssql_num rows0) 函 数 仅 对 select 语句 有 效 。 


囊 
次 


实例 484 


趣味 指数 : 交友 去 坟 


看 实例 说 明 

在 输出 数据 信息 后 要 及 时 释放 结果 内 存 以 节省 内 存 空间 。 也 许 用 户 会 觉得 ， 不 释放 结果 内 存 并 没有 什么 严 
重 影响 。 这 是 因为 用 户 本 机 上 运行 的 实例 数据 结果 很 小 ， 对 于 计算 机 运算 速度 来 说 没有 太 大 的 影响 ， 但 是 如 果 
结果 集中 包含 大 量 的 数据 ， 计 算 机 的 运算 速度 就 会 明显 变 慢 。 运 行 本 实例 ， 通 过 mssql_free_result() 函 数 释 放 结 
果 内 存 ， 如 图 10.17 所 示 。 


Li 


mssql free result() 国 数 的 应 用 .| 


2010/ 作 月 j31 0: 00 
2010/A 有 731 GO: 00 
Pe 
L 2010， 

nn UN ER 


图 10.17 释放 结果 内 存 


图 关键 技术 
本 实例 主要 应 用 mssql free_result0 函 数 释放 结果 内 存 ， 其 语法 如 下 : 
bool mssql free_result ( resource result ) 


该 函数 将 释放 所 有 与 结果 标识 符 result 相关 联 的 内 存 。 
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力 设计 过 程 


创建 index.php 脚本 文件 ， 包 含 数据 库 连 接 类 ， 对 类 进行 实例 化 操作 ， 完 成 与 db_database10 数据 库 的 连接 
并 循环 输出 数据 表 中 的 数据 ， 当 单 击 “ 释 放 结果 内 存 ” 超 链接 时 ， 执 行 释放 结果 集 的 操作 ， 代 码 如 下 : 
Ei include_once("conn.php"); // 包 含 数据 库 文件 


Sms = new Mssql("localhost"."sa",""."db_database10"); /实例 化 对 象 
Srs =mssql_query("select * from tb_demo10"): 


while($rst = mssql_feteh_row($rs){ /循环 输出 
?> 
<t> 

<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8',$rst[0]):?></td> 

td bgeolor="#FFFFFF"><?php echo iconv('gbk',utf-8',$rst[1]):?></td> 

<td bgcolor="#FFFFFF"><?php echo iconv('gbk',‘utf-8',$rst[2]):?></td> 

<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8',Srst[3]):?></td> 
< 


} 
if($_GET[d] — D{ 

Sms -> free_result($rs); /释放 结果 集 
} 


力 秘笈 心 ; 
心 法 领悟 484: 详解 mssql_free_result0 函 数 。 


mssql_free_result0 函 数 将 释放 所 有 与 结果 标识 符 result 相关 联 的 内 存 , 仅 需 要 在 考虑 到 返回 很 大 的 结果 集 时 
会 占用 较 多 内 存 时 调用 ， 在 脚本 结束 后 所 有 关联 的 内 存 都 会 被 自动 释放 。 


站 ee Od 机 
实例 485 5 趣味 指数 : 食 食 三 食 


力 实例 说 明 


在 程序 运行 结束 后 ， 不 但 要 释放 结果 内 存 ， 还 要 关闭 与 数据 库 的 连接 以 节省 系统 资源 。 运 行 本 实例 ， 单 击 
“关闭 连接 ” 超 链接 将 析出 提示 ， 运行 结果 如 图 10.18 所 示 。 


20L0/ 八 月 /3 0:00 
719 元 501W 入 月 / 红 0: 00 
1 玩 TAY AT) 


《PHP 开 发 安 小 宝 热 》 

《PAP 标准 教程 》 
《PHP 网 络 编 程 宝 积 》 

《PH 范例 室 禹 》 
《PHP 苑 例 手册 》 


图 10.18 关闭 与 数据 库 的 连接 


力 关键 技术 
本 实例 主要 是 通过 编写 数据 库 类 并 通过 对 象 句柄 调用 mssql_close0 函 数 ， 实 现 关闭 数据 库 连接 的 操作 。 其 
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中 mssql_close0 函 数 的 语法 如 下 : 


i 
参数 link_identifier 可 省 略 ， 是 SQL Server 的 连接 标识 符 。 


图 设计 过 程 


创建 index.php 脚本 文件 ， 包 含 数据 库 连 接 类 ， 对 类 进行 实例 化 操作 ， 完 成 与 db_database10 数据 库 的 连接 
并 循环 输出 数据 库 中 指定 数据 表 的 数据 ， 当 单 击 “ 关 闭 连 接 ” 超 链接 时 ， 执 行 关闭 数据 库 连接 的 操作 ， 其 代码 


如 下 : 
<?php 
include_once("conn.php"): 
Sms =new Mssql("localhost","sa","","db_database10"): 
Srs = mssql_query("select * from tb i 


hp 
while(Srst = mssql_feteh_row($rs){ 

?> 

<tr> 
<td bgcolor="#FFFFFF"><?php echo iconv(gbk','utf-8',Srst[0]):?></td> 
<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8',Srst[1]):?></td> 
<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8',Srst[2]):?></td> 
<td bgcolor="#FFFFFF"><?php echo iconv('gbk','utf-8',Srst[3]):?></td> 

</ltr> 

<?php 


} 
这 $_ 人 D{ 

$ms ->connect_close(); // 关 闭 数 据 库 连 接 
} 


> 


图 秘笈 心 法 

心 法 领悟 485， 使 用 mssql_close0 函 数 的 注意 事项 。 

本 函数 能 关闭 由 mssql_connectO) 函 数 打开 的 数据 库 ， 而 应 用 mssql_ pconnectO 函 数 打开 的 数据 库 则 不 能 以 本 
函数 关闭 。 


i 
an | NEA ee 
四 实例 说 明 


在 上 面 的 实例 中 ， 已 经 对 数据 库 连接 函数 做 了 初步 讲解 。 下 面 将 应 用 mssql_connect0 和 mssql_pconnectO 函 
数 编写 数据 库 连接 类 ， 运 行 本 实例 如 图 10.19 所 示 。 


10.19 与 数据 库 建立 永久 连接 


力 关键 技术 
在 本 实例 中 封装 一 个 数据 库 连接 类 Mssql， 定 义 构造 函数 为 成 员 变 量 赋值 ， 定 义 connect0 方 法 完成 与 SQL 
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Server 数据 库 的 连接 ， 其 中 通过 两 种 方法 连接 数据 库 ， 即 通过 mssql_ connectO 函 数 实现 与 数据 库 的 暂时 连接 、 
通过 mssql pconnectO 函 数 实现 与 数据 库 的 永久 连接 。Mssql 类 的 代码 如 下 : 


<php 
class Mssql{ 
var $host; 


public function __construct($host, Suser, Spwd,$conn){ /构造 函数 
Sthis -> host = $host 
Sthis -> user = $user; 
Sthis > pwd = $pwd; 
Sthis -> conn = $conn; 
Sthis -> connect|; 
} 
public function connectO{ 
这 Sthis -> conn 一 "pconn"){ 
Sthis -> conn = mssql pconnect($this -> hostSthis -> user.S$this -> pwd); 
echo "<script>alert( 与 SQL Server 数据 库 建 立 永 久 连 接 );</script>"; 
yelse{ 
Sthis -> conn = mssql connect($this -> host,$this -> user.S$this -> pwd); 
echo "<script>alert( 与 SQL Server 数据 库 建立 暂时 连接 ):</script>"; 
} 
} 
} 
> 


图 设计 过 程 
(1) 新 建 conn.php 文件 ， 编 写 数据 库 连接 类 ， 其 完整 代码 请 参考 关键 技术 中 的 内 容 。 


(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 提 交 连 接 数据 库 所 使 用 的 方式 。 然 后 包含 数据 库 连接 类 ， 执 行 
类 的 实例 化 操作 ， 并 调用 connect0 方 法 完成 与 数据 库 的 连接 ， 其 关键 代码 如 下 : 


<?php 
include_once("conn.php"): // 包 含 数据 库 连 接 类 
iflisset($_POST[sub]){ /判断 按钮 是 否 被 单 击 
if($_POST[select] — ""){ 1/ 判断 下 拉 列 表 框 内 容 
echo "<script>alert( 请 选择 连接 方式 ):</seript>";: 
jelsef 
Sms = new Mssql("localhost"."sa"."",$_POST[select]): /实例 化 对 象 
} 
} 
eg 
图 秘笈 心 法 


心 法 领悟 486:， 对 两 种 连接 方式 的 选择 。 

永久 连接 和 暂时 连接 从 功能 上 说 都 可 以 实现 与 数据 库 的 连接 操作 。 至 于 如 何 选择 ， 一 般 都 是 程序 员 的 个 人 
爱好 问题 。 笔 者 喜欢 用 暂时 连接 的 方式 ， 虽 然 在 操作 完 数据 库 后 须 及 时 关闭 与 数据 库 的 连接 ， 但 是 在 结构 上 较 
为 鲜明 。 


高 级 | 
趣味 指数 : 下 去 友 坟 友 | 


实例 487 


力 实例 说 明 


在 实际 Web 开发 过 程 中 ， 无 论 是 前 台 还 是 后 台 经 常会 用 到 向 数据 库 中 添加 信息 这 一 模块 ， 如 果 所 用 之 处 
都 要 重复 编写 代码 ， 这 会 使 整个 项 目的 代码 重用 率 大 大 降低 。 为 了 克服 上 述 缺陷 ， 可 以 通过 一 个 数据 信息 添加 
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类 来 实现 某 项 目 中 的 所 有 信息 的 添加 工作 。 运 行 本 实例 ， 图 书 添加 页 面 及 查看 图 书信 息 页 面 分 别 如 图 10.20 和 
10.21 所 示 ， 首 先 在 图 10.20 所 示 的 表单 中 输入 某 图 书 的 信息 ， 单 击 “ 添 加 ”按钮 即 可 将 图 书信 息 添加 到 数 
据 库 中 ， 同 时 可 以 在 图 10.21 所 示 的 页 面 中 查看 所 有 已 经 添加 的 图 书信 息 。 


| 
出 版 和 :|[ wa 明日 了 技 
放 考 :上 人 -得 提 革 开 妇 元 主 于 们 ) 本 日 R 技 
:| [EEC 了 EE TT 


EE | 加 加 加 
图 10.20 添加 图 书信 息 图 10.21 浏览 图 书信 息 


力 关键 技术 


本 实例 的 关键 是 如 何 编写 通用 的 添加 信息 类 ， 其 实现 的 基本 原理 是 : 通过 构造 函数 对 要 执行 的 SQL 语句 进 
行 初始 化 ， 这 样 即使 表 中 的 字段 数目 不 同 也 可 以 实现 将 图 书信 息 添加 到 数据 库 中 ，addbook 类 的 代码 如 下 : 


<php 

class addbook { 

private $add_sql; // 定 义 私有 变量 

public function __construct($x) { /定义 构造 函数 
Sthis->add sql= Sx; // 为 变量 赋值 

} 

public function add0 { // 定 义 添加 数据 的 方法 


include_once ("conn.php"); 
if (@mssql_query ( $this->add sql, Sconn )) { 

echo "<script>alert( 新 书 添加 成 功 !);history.back0:</script>"; 
}else{ 

echo "<seript>alert( 新 书 添加 失败 !"):history.back0:</seript>"; 
} 


} 

人 =$ POST [bookname]: 

S$auto =$_POST [auto]: 

Spub =$_POST [pub]; 

S$pubtime = $_POST [pubtime]: 

$sql = "insert into tb demo08(bookname.auto.pub.pubtime)jvalues('S$bookname'.$auto'.Spub''Spubtime)": 

Sadbook = new addbook ( $sql ); 

Sadbook->add (); 

> 

该 类 定义 一 个 私有 的 数据 成 员 $add_sql 用 于 保存 传 入 该 类 的 查询 语句 ， 并 通过 构造 函数 construct0 实 现 对 
该 私有 成 员 的 初始 化 ， 最 后 定义 该 类 的 成 员 函 数 add0 执 行 添加 操作 。 
力 设计 过 程 

(1) 新 建 conn.php 文件 ， 完 成 与 数据 库 的 连接 。 

(2) 新 建 addbook.php 文件 , 创建 form 表单 提交 要 添加 的 图 书信 息 ,将 图 书信 息 提交 到 savebook.php 文件 
中 。 添 加 图 书信 息 的 页 面 效果 如 图 10.20 所 示 。 

(3) 创建 savebook.php 文件 ， 编 写 数据 添加 类 ， 定 义 addbook0 方 法 执行 数据 的 添加 操作 。 在 该 文件 中 完 
成 类 的 实例 化 操作 ， 并 通过 返回 的 对 象 调用 类 中 的 addbook0 方 法 , 根据 表单 中 提交 的 数据 定义 insert 添加 语句 ， 
最 终 执行 数据 的 添加 操作 ， 其 代码 请 参考 关键 技术 中 的 内 容 。 

(4) 新 建 index.php 文件 ， 循 环 输出 数据 表 中 存储 的 图 书信 息 ， 其 关键 代码 如 下 : 
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inelude_once ("conn php"): 
$sql =mssql._query ( "select * from tb_demo08 order by pubtime dese", Sconn ); 


echo " 暂 无 图 书信 息 ! "; 
}elsef 
do 


<t> 
<td height="25" bgeolor="#FFFFFF"><div align="center><?php echo iconv ( 'gbk', utf-8' Sinfo [bookname] ):?><div><ltd> 
"bgcolor="HFFFFFF"><div align="center"><?php echo iconv ( ‘gbk, ‘utf-8', $info [auto] ); ?></div></td> 


ight="25" bgcolor="WFFFFFF"><div align="center”><?php echo iconv ( ‘gbk,, ‘utf-8', $info [pub] ):?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo iconv ( ‘gbk’, utf-8', $info [pubtime] ):?></div></td> 


} while ( Sinfo = mssql feteh_aray ($sql ) ); 
国 秘笈 心 法 
心 法 领悟 487: 构造 函数 的 对 应 函数 一 一 析 构 函数 。 


与 构造 函数 对 应 的 是 析 构 函数 ， 析 构 函 数 在 销毁 类 之 前 执行 ， 并 统一 命名 为 _destruct0， 其 作用 是 在 类 被 
销毁 前 自动 完成 某 项 功能 。 


实例 488 


力 实例 说 明 


面向 对 象 编程 对 于 一 个 优秀 的 PHP 程序 员 来 说 是 必须 具备 的 知识 。 本 实例 编写 一 个 删除 类 ， 实 现 删 除 图 书 
信息 的 操作 ， 运 行 结果 如 图 10.22 所 示 。 


PE 范例 宝 丙 妇 日 科技 有 有 限 公 ; | 人 民 闻 电 出 版 社 


PP 下 学 手册 明日 科技 有 有限 公司 ”| 。 人 人民 闻 电 中 慑 入 
PE 实战 宝 夫 明日 科技 有 限 公司 作 民 邮电 出 版 社 


10.22 ”删除 图 书信 息 


力 关键 技术 


数据 删除 类 DeleteDemo 继承 数据 库 连接 类 ConnDemo, 定义 SQL0 方 法 生成 delete 删除 语句 ; 定义 Delete0 
方法 ， 通 过 mssql_query0 函 数 执行 delete 删除 语句 ， 完 成 数据 的 删除 操作 。DeleteDemo 类 的 代码 如 下 : 


<?php 
include('conn.php)): /包含 数据 库 连接 类 
class DeleteDemo extends ConnDemof /| 继承 数据 库 连 接 类 
var $sql; // 定 义 变量 
public function SQL($id){ //SQL 语句 方法 
Sthis -> sql = $sql: 
Sthis -> sql= "DELETE FROM "Sthis -> tb." where id= Sid": /拼接 SQL 语句 
retum $this -> sql: /将 SQL 语句 返回 


} 
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public function DeleteO{ // 定 义 删除 方法 
if(!$rs = @mssql_query($this -> sqD){ // 如 果 执行 删除 操作 发 生 错 误 
echo "<script>alert(SQL 语句 错误 ");</script>"; //JavaScript 提示 
jelsef 


echo "<script>alert(' 删 除 成 功 ):location href='index.php?id=1';</script>"; 
8 
} 
} 


图 设计 过 程 
(1) 新 建 conn.php 文件 ， 编 写 数据 库 连接 类 ， 完 成 与 SQL Server 数据 库 的 连接 ， 其 代码 如 下 : 


<?php 
class ConnDemo{ // 定 义 类 名 称 
var $host; // 主 机 名 称 
var $user; /用 户 名 称 
varS$pwd; /用户 密码 
var $db; /| 数据 库 名 称 
Var $conn; /连接 标识 符 
var $tb; /数据 表 名 称 
Public function __construct($host,$user, Spwd,$db,Stb){ // 构 造 函 数 
Sthis -> host = $host; 
Sthis -> user = $user; 
Sthis -> pwd = $pwd; 
Sthis -> db = $db; 
Sthis -> tb = $tb; 
Sthis -> conneetO: 
} 
public function conneetO{ 


S$this -> conn = $conn; 
Sthis -> conn = mssql_connect($this -> host,$this -> user,$this -> pwd) or die ("Connect mssql false"); 
mssql select db($this -> db,$this -> conn) or die ("Connect Database false"): 
} 
} 


?> 
(2) 新 建 delete.php 文件 ， 编 写 数据 库 删 除 类 并 继承 数据 库 连接 类 ， 其 代码 如 关键 技术 中 所 示 。 
(3) 新 建 index.php 文件 。 首 先 创建 form 表单 ， 提 交 图 书 的 ID 值 作为 执行 删除 操作 的 条 件 。 然 后 包含 数 
据 删除 类 文件 ， 执 行 DeleteDemo 类 的 实例 化 操作 并 且 向 类 中 传递 参数 。 接 着 执行 查询 语句 ， 循 环 输出 数据 表 中 
的 数据 。 最 后 根据 form 表单 提交 的 值 ， 通 过 类 实例 化 返回 的 对 象 调用 Delete0 方 法 执行 删除 操作 ， 其 关键 代码 
如 下 : 


<?php 

include ("delete.php"): 

$dd = new DeleteDemo ( "localhost". "sa", "", "db_database10", "tb_demo09" );: 
if($_GET [id]="1") { 

Srst= mssql_query ( "select * from tb_demo09" ): 

?> 


<form action="" method="post"> 
<input type="text" size="10" name="text" value=" 输 入 ID 删除 " onfocus="this.value="" class="one" /> 
<input type="submit" name="sub" value="&nbsp:" class="two" /> 
</form> 
<table width="580px" bgcolor="#FA7672"> 
<tr> 
<td align="center"> 图 书 名 称 </td> 
<td align="center"> 作 者 </td> 
<td align="center"> 出 版 社 </td> 
<td align="center"> 出 版 时 间 </td> 
<ltr> 
<?php 
while ( Srstt = mssql_fetch_ row (Srst) ) { 
> 


<tr> 
<td bgcolor="#FFFFFF" align="center"><?php echo iconv ( ,gbk'. ‘utf-8', Srstt [0] ):?><ftd> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8", Srstt [11 ):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk’, ‘utf-8', Srstt [2] ):?></td> 
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<td align="center" bgcolor="#FFFFFF"><?php echo iconv ( ‘gbk', ‘utf-8', Srstt [3] ):7></td> 
</tr> 
Bo 


} 

if($_POST [sub]) { // 判 断 提 交 按 钮 的 值 
Ste =$_POST[text]; /| 获取 提交 的 人 
$dd -> SQL(Ste): /调用 SQL 方法 定义 delete 删除 语句 
$dd -> Delete0: // 调 用 Delete0 方 法 执行 删除 操作 


图 秘 稚 心 法 


心 法 领悟 488: 类 的 继承 。 
少数 面向 对 象 的 语言 (如 C++、Smalltalk 等 ) 支持 多 继承 ， 即 一 个 子 类 有 多 个 父 类 。 但 是 PHP 自身 不 支持 
多 继承 ， 只 支持 单 继 承 ， 即 一 个 子 类 只 有 一 个 父 类 。 


本 高 级 | 
实例 489 | 起 味 指数 : 贾 页 页 页 | 
图 实例 说 明 


实现 更 新 图 书信 息 类 与 删除 图 书信 息 类 大 同 小 异 ， 只 是 将 删除 图 书信 息 类 中 的 两 个 核心 方法 蔡 换 为 更 新 操 
作 的 方法 即 可 。 运 行 本 实例 ， 执 行 图 书信 息 的 更 新 操作 ， 其 运行 效果 如 图 10.23 所 示 。 


因 书 情 息 
选择 妥 更 新 的 字 发 名 个 国 书 名 入 但 作者 个 出 版 社 个 出 版 日 期 
a 


[rE EE 


0 人 月 /11 0: 00 


CRA 
0 入 月 11 0;00 


10.23 更 新 图 书 类 的 实现 


力 关键 技术 


更 新 图 书 类 UpdateDemo 同样 集成 数据 库 连 接 类 ConnDemo， 与 数据 库 删 除 类 的 唯一 不 同 之 处 是 在 SQL 方 
法 中 定义 的 是 update 更 新 语句 。UpdateDemo 类 的 代码 如 下 : 


class UpdateDemo extends ConnDemo{ /| 继承 抽象 类 

var $sql; // 定 义 变量 

public function SQL($Condition1,$Condition2.$id){ // 定 义 方法 拼接 字符 串 
Sthis -> sql = $sql: 
S$this -> sql = "update ".$this -> tb." set $Condition1='$Condition2' where id=$id"; // 拼 接 字 符 串 
return $this -> sql: 

public function updateO{ // 更 新 操作 方法 
if($result = mssql_ query(Sthis -> sqD){ 

echo "<script>alert( 更 新 操作 以 成 功 ):location href='index .php?id=1':</script>"; //JavaScript 提示 

jelsef 


echo "<script>alert(SQL 语句 发 生 错 误 );</script>"; 
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有 


图 设计 过 程 
(1) 在 conn.php 文件 中 ， 首 先 编写 ConnDemo 数据 库 连 接 类 ， 通 过 connect() 方 法 完成 与 SQL Server 数据 
库 的 连接 。 本 部 分 采用 编写 抽象 类 实现 ， 代 码 如 下 : 


<php 
abstract class ConnDemo{ /抽象 类 
var $host; // 主 机 名 称 
var $user; // 用 户 名 称 
var Spwd; // 用 户 密码 
var $db; /数据 库 名 称 
var $tb; /数据 表 名 称 
var $sql; //SQL 语句 
public function __construct($host, Suser, Spwd,$db.$tb){ 1/ 构造 函数 
Sthis -> host = $host; 
Sthis -> user = $user; 
Sthis -> pwd = Spwd: 
Sthis -> db = $db; 
Sthis -> 也 = $tb; 
Sthis -> conneetO: 
} 
public function connectO{ // 连 接 方法 
Sthis -> conn = $conn; 
Sthis -> conn = mssql_connect($this -> host,$this -> user,$this -> pwd) or die ("Connect SQL Server false"); 
mssql select db($this -> db,$this -> conn) or die ("Connect Database false"); 
} 
public abstract function update(); /抽象 方法 
} 
> 


(2) 在 conn.php 文件 中 ， 编 写 数据 库 更 新 类 UpdateDemo， 继 承 自 数 据 库 连 接 类 并 重 写 抽象 方法 ， 定 义 
SQL0 方 法 和 Update0 方 法 实现 数据 的 更 新 操作 ， 其 代码 见 关 键 技术 。 

(3) 新 建 index.php 文件 。 首 先 包含 conn.php 文件 ， 实 例 化 数据 库 更 新 类 UpdateDemo。 然 后 执行 查询 语 
句 ， 循 环 输出 数据 表 中 的 数据 。 接 着 创建 form 表单 ， 提 交 要 更 新 的 数据 到 本 页 。 最 后 根据 表单 中 提交 的 数据 ， 
调用 数据 库 更 新 类 UpdateDemo 中 的 方法 执行 更 新 操作 ， 其 关键 代码 如 下 : 


<?php 
if$_POST[sub]){ // 单 击 按钮 
if($_POST[check] =—""){ 1/ 判断 单 选 按钮 是 否 被 选中 
echo "<script>alert(' 请 选择 要 更 新 的 字段 名 称 "):location.href='index.php?id=1':</script>"; //JavaScript 提示 
jelse{ 
这 $_POST[te] 一 "输入 更 新 内 容 和 图 书 ID 并 用 空格 分 割 ){ 1/ 判断 文本 框 是 否 有 内 容 
echo "<script>alert(' 请 书写 更 新 内 容 和 图 书 ID ):location hre 人 index.php?id=1':</script>": 。 /JavaScript 提示 
yelse{ 
Sarray = explode(" ".$_POST[te]): // 字 符 串 拆 分 
if(count($array) > 2 || count(Sarray) 一 1){ // 判 断 拆 分 后 的 数组 长 度 
echo "<script>alert(' 文 本 框 输入 内 容 有 误 "):</script>"; //JavaScript 提示 
Jelse{ 
if(!preg_match("/\d/",Sarray[1D){ 1/ 判断 拆 分 后 的 ID 是否 为 数字 
echo "<script>alert( 输入 的 图 书 ID 不 是 数字 或 不 在 范围 ):location href='index.php?id=1';</script>"; 
jelse{ 
S$str =$_POST[check]: 
S$strl = iconv(utf-8'gbk .Sarray[0]): 
$id = Sarray[1]: 
S$ud -> SQL(S$str,$str1.$id): /调用 类 中 方法 并 传递 参数 
Sud -> update0: /调用 更 新 方法 
} 
} 
} 
} 
} 
> 
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心 法 领悟 489: 抽象 类 。 
抽象 类 与 普通 的 类 在 形式 上 没有 太 多 的 差别 。 抽 象 类 中 必须 存在 至 少 一 个 抽象 方法 ， 其 好 处 在 于 被 其 他 的 
子 类 继承 时 可 以 选择 性 地 执行 其 中 的 一 个 或 多 个 抽象 方法 。 
入 页 码 跳 转 到 指定 页 高 级 | 
趣味 指数 : dodolol 


实例 490 


力 实例 说 明 

分 页 显示 模块 的 页 码 跳 转 方式 有 多 种 ， 比 如 单 击 页 码 跳 转 、 从 下 拉 列 表 框 中 选择 页 码 实现 跳 转 等 。 或 许多 
数 程序 员 已 经 熟悉 通过 函数 方式 实现 分 页 ， 而 本 例 将 介绍 如 何 通过 ADO 方式 操纵 SQL Server 数据 库 实现 分 页 
显示 。 熟悉 ASP 的 读者 可 能 会 发 现 , 采用 这 种 方式 实现 分 页 与 ASP 通过 记录 集 实现 分 页 的 方式 类 似 。 运 行 本 实 
例 ， 如 图 10.24 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 要 跳 转 的 页 码 ， 然 后 单 击 GO 按钮 ， 即 可 实现 页 码 跳 转 。 
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图 10.24 输入 页 码 跳 转 到 指定 页 


图 关键 技术 


为 了 方便 操作 ， 本 实例 将 采用 GET 方法 提交 用 于 输入 页 码 的 表单 ， 这 样 做 的 目的 是 使 通过 单 击 页 码 实 现 的 
跳 转 与 通过 在 文本 框 中 输入 页 码 实现 的 跳 转 都 用 $_GET[] 进 行 接收 , 否则 还 得 单独 做 一 个 用 $_POSI[] 数 组 接收 提 


交 的 页 码 的 模块 。 通 过 form 表单 完成 页 码 跳 转 的 代码 如 下 : 
<form action="index.php" method="get" name="forml" id="form1"> 
<tr> 


<td width="30"> 
<div align="center"><input type="text" name="page" size="2" class="inputess" /></div> 
<ltd> 
<td width="40"> 
<div align="center"><input name="submit" type="submit" class="buttoness" value="GO" /></div> 

<ltd> 
</tr> 
</form> 

图 设计 过 程 
(1) 新 建 conn.php 文件 ， 通 过 ADO 连接 SQL Server 数据 库 ， 其 代码 如 下 : 

<2php 
Sconn=new com("adodb.connection"); /| 创建 记录 集 
Sconnstr="provider=sqloledb:data source=localhost:uid=sa:pwd=:database—db_database10"; /| 连接 SQL Server 数据 库 
$conn->open($connstr); // 返 回 连接 对 象 


> 


(2) 编写 代码 用 于 接收 查询 字符 串 的 值 〈 该 值 代表 要 跳 转 的 页 ) 并 实现 分 页 显示 ， 代 码 如 下 : 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


<?php 

include ("conn.php"); 

$sql = "select * from tb_demo06 order by pubtime dese": 

Srs =new com ( "adodb.recordset" ): 

Srs->open ( $sql, $conn, 1, 1 ); 

Srs->pagesize = 5; 

if((trim (intval ($_GET [page] ))—"") | (intval ($_GET [page] ) > Srs->pagecounb | (intval ( $_GET [page] ) 一 0) { 


Spage =intval ( $_GET [page] ): 


} 
f (Srs->eof | Srs->bof) { 
echo " 暂 无 主题 "; 
}else{ 
Srs->absolutepage = Spage: 
Smypagesize = Srs->pagesize; 
> 
<table width="753" height="50" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td bgeolor="#666688"> 
<table width="753" height="50" border="0" cellpadding="0" cellspacing="1"> 
<t> 


<td width="325" height="25" bgcolor="#79D1E7"><div align="center"> 主 题 </div></td> 
<td width="188" bgcolor="#79D1E7"><div align="center"> 发 表 时 间 </div></td> 
<td width="126" bgcolor="#79D1E7"><div align="center"> 发 表 人 </div></td> 
<td width="109" bgcolor="#79D1E7"><div align="center"> 浏 览 次 数 </div></td> 
</tr> 
<?php 
while ( ! $rs->eof && Smypagesize > 0 ) { 
> 
<tr> 
<td height="25" bgcolor="#FFFFFF"> 
<div align="left"><?php echo iconv ( ‘gbk', ‘utf-8', $rs->fields ( title )->value ); ?></div> 
<hd> 
<td height="25" ><div align="center"><?php echo iconv ( ‘gbk’, ‘utf-8', $rs->fields ( pubtime )->value ); ?></div> 
<hd> 
<td height="25" ><div align="center"><?php echo iconv ( ‘gbk’, ‘utf-8', $rs->fields ( pubuser )->value ); ?></div> 
</td> 
<td height="25" ><div align="center"><?php echo iconv ( ‘gbk’, ‘utf-8', $rs->fields ( click )->value ); ?></div> 
<htd> 
</> 
<?php 
Smypagesize 一: 
$rs->movenext' 
} 
} 
?> 
</table> 
<ltd> 
</t> 
</table> 


(3) 创建 分 页 超 链接 ， 通 过 GET 方法 提交 page 的 值 ， 从 而 实现 页 码 跳 转 ， 其 关键 代码 如 下 : 

<table width="754" border="0" align="center" cellpadding="0" cellspacing="0"> 
<t> 

<td width="338" height="25"> 

<div align="left"> 共有 主题 <?php echo $rs->recordcount?> 个 &nbsp: 每 页 显示 <?php echo Srs->pagesize:?> 个 &nbsp: 第 <?php echo $Spage:?> 
页 / 共 <?php echo $rs->pagecount:?> 页 </div> 

<htd> 

<td width="345"> 

<div align="right"> 

<?php 

if (Spage >—2) { 
> 


<a href="index.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> 
<a href="index.php?page—<?php echo Spage - 1; ?>" title=" 前 一 页 "><font face="webdings"> 7 </font></a> 
<?php 

} 

f($rs->pagecount <=4) { 
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for($i= 2 $1 <= $rs->pagecount; $i1++) { 
<a href="index.php?page=<?php ce 2>"><?php echo $i:7></a> 
<php 


jslse t 
for($i=1; $1<—4: $i+7) { 
<a href="index php?page=<?php echo ie echo $i;7></a> 
<Iphp 
<a href="index php?page=<?php 1) echo Spage + 1; else echo 1; ?>" tile=" 后 一 页 "><font face="webdings"> 8 
por echo S$rs->pagecount; ?>" title=" 尾 页 "><font face="webdings"> : <ffont></a> 
} 


?> 
</div> 
<td> 
</t> 
</table> 


图 秘笈 心 ; 


心 法 领悟 490， 表单 提交 的 两 种 方式 。 

提交 表单 可 以 采取 POST 和 GET 两 种 方式 ， 这 两 种 方式 的 区 别 是 : 使 用 POST 方法 提交 的 信息 在 地 址 栏 中 
不 显示 ， 并 且 用 $_POST[] 数 组 接收 提交 的 内 容 。 而 采用 GET 方法 提交 的 信息 在 地 址 栏 中 显示 ， 如 果 提 交 多 个 信 
息 ， 则 信息 之 间 用 “&” 连 接 ， 并 且 提 交 的 内 容 用 $_GET[] 数 组 进行 接收 。 


Ee RR 站 
起 呆 朱 才 ; 帘 页 宙 od 


力 实例 说 明 


通过 单 击 页 码 跳 转 到 指定 页 ， 是 众多 分 页 方式 中 应 用 最 广泛 的 一 种 ， 通 过 这 种 方式 可 以 浏览 某 一 模块 中 的 
所 有 信息 。PHP 操作 MySQL 数据 库 实现 分 页 显示 主要 通过 关键 字 limit 实现 ,但 limit 关键 字 只 是 MySQL 数据 
库 的 扩展 部 分 , 不 能 被 SQL Server 数据 库 识 别 ， 所 以 本 实例 将 采取 一 种 特殊 方式 实现 SQL Server 数据 库 信息 的 
分 页 展示 。 运 行 本 实例 ， 如 图 10.25 所 示 ， 通 过 单 击 图 中 页 码 超 链接 即 可 实现 不 同 页 之 间 的 跳 转 。 
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图 10.25 利用 et 函数 库 实现 指定 页 跳 转 


图 关键 技术 


本 实例 采用 mssql 函数 库 ， 通 过 面向 过 程 的 方式 实现 数据 的 分 页 输出 ， 其 基本 原理 是 : 在 获取 数据 表 中 总 
的 记录 数 后 ， 通 过 标记 变量 $i 来 控制 显示 记录 的 范围 从 而 实现 分 页 操作 ， 其 关键 代码 如 下 : 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


<?php 

include_once ("conn.php"); /包含 数据 库 连 接 文件 
$sql = mssql query ( "select * from tb_demo07 order by pubtime dese", Sconn ); /执行 查询 

$sqll = mssql_query ( "select count(*) as total from tb_demo07", $conn ): /统计 记录 数 

Sinfol = mssql fetch_array ( $sqll ); /获取 查询 结果 集 


Stotal = $infol [total]; 
if($_GET [page] —""||is numeric ($_GET [page] ) — false) { 


Spage =1; // 定 义 分 页 变量 
}else { 
Spage =$_GET [page]; 1/ 获取 当前 页 码 
} 
Spagesize = 5; // 定 义 每 页 显示 记录 数 


让 (Stotal % $pagesize — 0) { 

Stotalpage = $total / $pagesize; 
}else{ 

Stotalpage = ceil ( $total / $pagesize ); 


} 

和 = 

while ( $info = mssql fetch array ( $sql )) { /| 循环 输出 查询 结果 
证 (Si > $pagesize * (Spage - 1) && $i <= Spagesize * Spage) { 
> 


<tr> 
<td height="25" bgcolor="#FFFFFF"> 
<div align="left"><?php echo iconv ( ‘gbk', utf-8', $info [title] ):?></div> 
<ktd> 
<td height="25" bgcolor="#FFFFFF"> 
<div align="center"><?php echo iconv ( ‘gbk’, ‘utf-8', $info [pubtime] ):?7></div> 
<ltd> 
<td height="25" bgeolor="#FFFFFF"> 
<div align="center"><?php echo iconv ( ‘gbk’, ‘utf-8', $info [pubuser] ):?7></div> 
</td> 
<td height="25" bgcolor="#FFFFFF"> 
<div align="center"><?php echo iconv ( 'gbk’, utf-8", Sinfo [click] ); ?></div> 
<ltd> 
</t> 


<?php 


有 + 
} 


?> 
四 设计 过 程 
(1) 新 建 conn.php 文件 ， 通 过 mssql 函数 库 完成 与 SQL Server 数据 库 的 连接 。 
(2) 创建 index.php 文件 ， 包 含 数 据 库 连 接 文件 ， 查 询 指定 数据 表 中 的 数据 ， 并 且 统计 总 的 记录 数 ， 定 义 


分 页 变量 ， 通 过 标记 变量 $i 来 控制 显示 记录 的 范围 ， 其 代码 请 参考 关键 技术 中 的 内 容 。 
(3) 创建 分 页 超 链接 ， 完 成 数据 的 分 页 显示 ， 其 代码 如 下 : 


<table width="754" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 

<td width="338" height="25"> 

<div align="left"> 共 有 主题 <?php echo $total:?> 个 &nbsp: 每 页 显示 <?php echo $pagesize:?> 个 &nbsp: 第 <?php echo $page:?> 页 / 共 <?php 
echo S$totalpage:?> 页 </div> 

<htd> 

<td width="346"> 

<div align="right"> 
<?php 
for($i= 1; $i<= Stotalpage: $i ++) { 

> 


<a href-"index php?page—<?php echo $i:7>"><?php echo $i:7></a> 
<?php 

1 

2> 


</div> 

<td> 

<td width="70">&nbsp:<ltd> 
<i> 
</table> 
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利用 这 种 方法 实现 数据 库 信息 的 分 页 输出 并 不 是 将 焦点 放 在 数据 库 中 ， 而 是 无 论 当前 显示 的 是 哪 一 页 都 从 
数据 库 中 提取 出 所 有 的 记录 。 


心 法 领悟 491: 分 页 原理 。 
在 本 实例 中 ， 只 显示 $pagesize*($page-1) 与 $i<=$pagesize*$page 之 间 的 记录 ， 通 过 接收 不 同 的 Spage 值 来 判 
断 当前 应 显示 哪 一 页 。 


10.3 SQL Server 数据 库 的 综合 应 用 


本 节 以 SQL Server 数据 库 为 后 台 支 持 ， 将 整个 网 站 的 制作 过 程 分 成 若干 模块 进行 逐一 讲解 。 


力 实例 说 明 


“明日 编程 词典 一 一 在 线 体验 版 ”网 站 首页 应 用 框架 设计 ， 模 拟 编程 词典 软件 的 页 面 布局 ， 其 首页 的 设计 
效果 如 图 10.26 所 示 ， 其 中 包括 网 站 模块 导航 、 功 能 导航 条 、 内 容 树 状 导 航 、 内 容 展 示 区 和 滚动 导航 条 。 


内 容 树 状 导航 


图 10.26 “明日 编程 词典 一 一 在 线 体验 版 ”首页 


图 关键 技术 


“明日 编程 词典 一 一 在 线 体验 版 ”网 站 首页 应 用 框架 设计 将 文件 分 配 为 如 下 所 示 。 
框架 主体 文件 :index.html、index.php。 
网 站 模块 导航 : pd_top.html、pd_top.php。 
内 容 树 状 导航 : pd_left.html、pd _left.php。 
功能 导航 条 : pd_title html、pd_title php。 
内 容 展 示 区 : pd_main html、pd_main php。 
滚动 导航 条 : pd_bottom.html、pd_bottom.php。 


回回 回回 罗 加 


PHP 开发 实例 大 全 (基础 卷 ) 
其 frame 框架 的 布局 如 下 : 


<frameset rows="93,#.25" frameborder="0"> 
fame sspd top Phpneorn type™ (Seomn WE nerne "iopwindom" serolling "nor> 
<frameset cols="2( 
i a type={$conn type}" name="leftwindow" frameborder="1"> 
<frameset rows="37,+" frameborder="0"> 
<frame sre="pd. title.php" name="titlewindow" scrolling="no"> 
<frame sre="pd_main php" name="mainwindow" scrolling="auto" frameborder="1"> 


<frame sre="pd._bottom php" name="bottomwindow" scrolling="no" frameborder="1"> 
</frameset><noframes></noframes> 


图 设计 过 程 
“明日 编程 词典 一 一 在 线 体验 版 ”网 站 首页 文件 包括 模板 页 index.html 和 动态 文件 index.php。 


在 index.html 模板 页 中 ， 应 用 框架 技术 设计 网 页 的 布局 。 
在 index.php 文件 中 ， 首 先 包含 Smarty 配置 文件 ， 然 后 创建 模板 变量 ， 最 后 指定 模板 页 ， 其 代码 如 下 : 
<php 


require_once("system/systenm.inc.php"); // 调 用 配置 文件 
$smarty->assign('conn_ type\$_GET[conn typc]): /设置 模板 变量 
Ssmarty->display('index.html); // 指 定 模板 页 
> 

力 秘笈 心 法 


心 法 领悟 492: 页 面 框架 。 
所 谓 框架 是 指 网 页 的 各 部 分 是 相互 独立 的 页 面 ， 通 过 一 个 网 页 组 成 一 个 完整 的 网 页 显示 在 浏览 器 中 ， 重 复出 
现 的 内 容 被 固定 下 来 ， 每 次 浏览 者 发 出 对 网 页 的 请 求 时 ， 只 需 下 载 发 生变 化 的 框架 页 面 ， 其 他 的 页 面 保持 不 变 。 


力 实例 说 明 


网 站 模块 导航 根据 网 站 的 LOG 中 传递 的 参数 进行 跳 转 ， 如 果 LOG 中 传递 的 是 入 门 的 数据 ， 那 么 网 站 模块 
导航 中 将 输出 入 门类 中 的 功能 模块 ， 如 图 10.27 所 示 。 


开发 应 用 


| Ld 
从 时 天 好“| 入 JJ 志 h 反 高。 过 PS 中 加 于 其 


10.27 入 门类 中 功能 模块 展示 
如 果 LOG 中 传递 的 是 开发 的 数据 ， 那 么 网 站 模块 导航 中 将 输出 开发 类 中 的 功能 模块 ， 如 图 10.28 所 示 。 


10.28 开发 类 中 功能 模块 展示 
如 果 LOG 中 传递 的 是 应 用 的 数据 ， 那 么 网 站 模块 导航 中 将 输出 应 用 类 中 的 功能 模块 ， 如 图 10.29 所 示 。 


10.29 ”应 用 类 中 功能 模块 展示 
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图 关键 技术 


网 站 模块 导航 中 包含 两 项 技术 : 
第 一 项 技术 : 通过 js 脚本 向 FLASH 中 传递 参数 。 
(1) 创建 js 脚本 文件 flash1.js， 定 义 向 FLASH 中 写 入 的 内 容 ， 其 代码 如 下 : 


function flash1 (mm) { 
var flash2="<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download macromedia.com/pub/shockwave/cabs/ 
flash/swflash.cabiversion=7,0,19.0" width="171" height="93">"; 
@ flash2+='<param id="swf" name="movie" value="images/bccd.swf?conn type="+mt">"; 
flash2+="<param name="quality" value="high">"; 
flash2+="<param name="allScriptAccess" value="always"/>'; 
flash2+="<param name="wmode" value="transparent'>': 
flash2+="<embed sre="images/bced.swf" width="171" a quality="high" pluginspage="http://www.macromedia.com/go/getflashplayer'" 
type="application/x-shockwave-flash" wmode="transparent"></embed>" 
flash2+="</object>'; 
@ 。 documentwrite(flash2): 
也 


es 

ER 代码 导读 
@ param id="swf': 在 swf 的 url 中 传递 参数 值 。 
@ document.write: 执行 写 入 操作 。 


(2) 在 FLASH 元 件 中 通过 on(release) 方 法 获取 传递 的 参数 值 ， 并 执行 超 链 接 。 


加 ”通过 this.loaderinfo.parameters["conn_ type"] 获 取 传 递 的 参数 值 ， 代 码 如 下 : 
var type=this.loaderinfo.parameters["conn_type"]: 
FLASH 中 的 编辑 效果 如 图 10.30 所 示 。 
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10.30 通过 变量 传递 参数 
回 “” 通过 getURL0 方 法 执行 超 链 接 ， 代 码 如 下 : 
getURL("pd_left.php?conn_id=20510111&table_name=study&class_type= 从 零 开 始 &conn_type=type", "leftwindow", "GET"); 
FLASH 中 的 编辑 效果 如 图 10.31 所 示 。 
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图 10.31 通过 getURL 执行 超 链接 


(3) 在 本 程序 使 用 的 FLASH 中 创建 3 个 元 件 ， 分 别 对 应 入 门 、 开 发 和 应 用 3 个 模块 。 
元 件 1 的 脚本 代码 如 下 : 


(release) { 
二 Joaderinfo .parameters["conn_type"]: 
getURL("pd left.php?conn id-20510111&rtable_name=study&class_ type= 从 零 开 始 &conn type=type". "leftwindow", "GET"): 
} 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
元 件 2 的 脚本 代码 如 下 : 


on (release) { 

var type=this.loaderinfo.parameters["conn type"]: 

getURL("pd left.php?conn id=10121002&table_name=jszx&zclass_type= 技 术 中 心 &conn_type=type", "leftwindow", "GET"); 
} 


元 件 3 的 脚本 代码 如 下 : 

on (release) { 

var type=this.loaderinfo.parameters["conn type"]; 

ee lefi.php?conn id=10127105&table_ name=ymzx&zclass_type= 源 码 管理 &conn_type=type", "leftwindow", "GET"); 


第 一 项 技术 : 在 超 链接 中 应 用 onMouseOver 和 onMouseOut 事件 调用 JavaScript 脚本 中 的 方法 , 控制 鼠标 滑 


过 超 链接 图 片 时 的 样式 。 超 链接 的 设置 如 下 : 
<a href="pd_left.php?conn id=20510111&table_name=study&class_type= 从 零 开始 " target="leftwindow"><img 
sre="images/accidence/images_01.jpg" border="0" id="Imagel" onMouseOver="MM_swapImage('Imagel',",images/accidence/images_001.jpg',1)" 
onMouseOut="MM_swapImgRestore()" /></a> 


JavaScript 脚本 中 定义 的 方法 如 下 : 
function MM _preloadImagesO { //v3.0 
ES 
RN 
f(alilindexOf("#")!=0){ dMM plil=new Image: dMM pli++l].sre=afil:}} 


} 
function MM_swapImgRestore() { //v3.0 
varixa=documentMM sr for(i=0:a&&i<alength&&(x=a[i)&&x.oSrc:itH) x.sre=x.0Sre; 


} 
function MM._findObj(n, d) { //v4.01 
var piiix; 这 ld) d=document; if((p=n.indexOf("?"))>0&&parent frames length) { 
d=parent.frames[n.substring(p+1)].document: n=n.substring(0.p):} 
if(!(x=d[n])&&ed all) x=d.all[n]: for (=0:!x&&i<d forms.length:it+) x=d.forms[i][n]: 
for(i=0;!x&&d layersé&&i<d layers length:it+) x=MM_findObij(n,.d .layers[i]. document); 
if(Ix &é& d.getElementById) x=d.getElementById(n); retum x; 
} 
function MM._swapImage() {//v3.0 
var ij=0,x,a=MM_swapImage.arguments: document MM_sr=new Array: for(i=0:i<(alength-2):i+=3) 
if((x=MM_findObj(afi])!=null) {document. MM._srlj++ J=x: if(!x.oSre) x.oSre=x.sre; x.sre=a[i+2]:} 
} 


图 设计 过 程 
网 站 模块 导航 的 实现 主要 应 用 到 pd_top.html 和 pd_top.php， 以 及 js 文件 夹 下 的 flashl.js 和 topjs 文件 。 
(1) 创建 pd_top.php 文件 ， 其 主要 功能 是 定义 模板 变量 传递 参数 以 及 指定 模板 页 ， 其 代码 如 下 : 


< 

ee // 初 始 化 SESSION 变量 

require_once 'system/system.inc.php'; // 包 含 配置 文件 、 数 据 库 连 接 、 操 作文 件 
S$smarty->assign('conn_id',$_GET['conn_id"]); // 定 义 模板 变量 传递 参数 
SA /指定 模板 页 


(2) 创建 模板 页 pd_top.html。 首 先 通过 script 标签 调用 js 脚本 文件 夹 下 的 topjs 和 flashl.js 文件 。 然 后 定 
义 JavaScript 脚本 ， 执 行 flash10 方 法 ， 向 FLASH 中 传递 参数 值 。 最 后 根据 模板 变量 $conn_id 的 值 进行 判断 ， 从 
而 输出 不 同类 别 的 功能 模块 ， 并 为 输出 的 功能 模块 创建 超 链接 , 链接 到 pd_left.php 文件 ， 同 时 传递 相应 的 参数 ， 
其 关键 代码 如 下 : 
<html> 


<head> 
‘<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title>{$conn_type} 编 程 词典 </title> 
<lhead> 
<link rel="stylesheet" type="text/css" href="css/link.css"></link> 
@<script type="text/javascript" sre="js/top.js"></script> 
@<script sre="js/flash1 js"></script> 
@<body onLoad="MM_preloadImages(images/criterion/images002 jpg’)"> 
<div style="padding-top:inherit width:100%; height: 93px: background:url(images/images_09.ipg):"> 
<div style="padding-top:inherit width:171px: height: 93px: float:left; "> 
Ee type= "textliavascript"> 

hashl( {$conn_type} 
水 
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<div> 
<div id="conn" style=" padding-top:0px: width:8096: height: 93px: float:right:"> 
© {ff$conn id 一 20510111 or $conn id—" 
<div id="accidence" style="padding-top:Opx: width: 100%; height 93px: "> 

<nl> 
© li style="display:inline; width: 89px: height: 93px: float: center text-align:center; «font-size: 12px"><a 
href="pd_left.php?conn_id=20510111&table_name=study&class_type= 从 零 开始 " target="leftwindow"><img src="images/accidence/images_01jpg” 
border="0" id="Imagel1" onMouseOver="MM swaplmage(Tmagel'.",images/accidence/images 001.ipg',1)" onMouseOut="MM swapImgRestore()" 
P</a></> 

<li style="display:inline; width: 94px; height: 93px; float: center:; text-align:center; font-size: 12px"><a 

href="pd_left.php?conn_id=20610111&table_name=works&zclass_type= 入 门 训练 " target="leftwindow"><img src="images/accidence/images_02.jpg” 
border="0" id="Image2" onMouseOver—="MM._swapImage(Tmage2',",images(accidence/fimages 002.ipg'1)" onMouseOut="MM_swapImgRestore()" 


<div> 


国 秘笈 心 法 

心 法 领悟 493: 代码 导读 。 

@ topjs: 导入 的 js 脚本 文件 ， 控 制 超 链接 图 片 的 样式 。 

@ flashljs: 向 FLASH 中 传递 参数 使 用 的 方法 。 

@ MM _preloadImages: 通过 onLoad0 事 件 调用 topjs 中 定义 的 方法 。 

@ flash10: 执行 ashl,js 脚本 中 定义 的 方法 ， 并 传递 参数 {$conn type} 。 

@ {if $conn id==-'20510111' or $conn_id 一 "}: 通过 Smarty 模板 中 的 站 语句 判断 网 站 模块 属于 哪 一 类 。 

@ 定义 超 链接 ,链接 到 pd_left.php 文件 ， 并 传递 相应 的 参数 值 ， 同 时 应 用 onMouseOver 和 onMouseOut 事 
件 调用 JavaScript 脚本 中 的 方法 ， 控 制 超 链接 图 片 的 样式 。 


力 实例 说 明 


内 容 树 状 导航 根据 网 站 模块 导航 中 传递 的 参数 值 进行 判断 ， 从 而 通过 树 状 导航 菜单 输出 对 应 功能 模块 中 包 
含 的 内 容 。 

在 内 容 树 状 导航 中 不 仅 包含 pd_left.html 和 pd_leftphp 两 个 文件 , 它 需 要 根据 网 站 模块 导航 中 传递 的 参数 值 
来 调用 入 门类 (accidence.html、 accidence.php) 、 开 发 类 (developer.html、 developer.php ) 或 者 应 用 类 (criterion .html、 
criterion.php) 的 内 容 。 

如 果 是 入 门类 ， 内 容 树 状 导航 中 默认 展示 的 是 “从 零 开 始 ” 功 能 模块 的 内 容 ， 如 图 10.32 所 示 。 
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转 意 的 私人 编程 专家 
图 10.32 入 门类 的 内 容 树 状 导航 
如 果 是 开发 类 ， 内 容 树 状 导航 中 默认 展示 的 是 “技术 中 心 ”功能 模块 的 内 容 ， 如 图 10.33 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 
如 果 是 应 用 类 ， 内 容 树 状 导航 中 默认 展示 的 是 “源码 管理 ”功能 模块 的 内 容 ， 如 图 10.34 所 示 。 


ae | 专业 出 版 专业 局 质 量 FE | 专业 出 版 专业 局 质 
图 10.33 开发 类 的 内 容 树 状 导航 图 1034 ”应 用 类 的 内 容 树 状 导航 
图 关键 技术 


在 内 容 树 状 导航 中 , 根据 网 站 模块 导航 中 传递 的 参数 值 , 控制 框架 中 topwindow( 网 站 模块 导航 )、leftwindow 
(内 容 树 状 导航 》 和 mainwindow〔 内 容 展示 区 ) 3 部 分 内 容 的 输出 ， 其 应 用 到 的 技术 如 下 : 
(1) switch 条 件 控制 语句 。 

在 pd_left.php 文件 中 ， 通 过 $_GET 方法 获取 网 站 模块 导航 中 参数 conn_id 传递 的 值 ， 并 将 该 值 作为 switch 
语句 执行 的 条 件 ， 与 case 关键 字 指 定 的 值 进行 判断 ， 如 果 相同 则 执行 相应 的 操作 ， 首 先 将 一 个 模板 页 赋 给 一 个 
模板 变量 。 然 后 通过 script 标签 向 topwindow 中 的 pd_top.php〔 网 站 模块 导航 〉 文件 传递 参数 。 最 后 通过 script 
标签 向 mainwindow 中 的 pd_main.php〔 内 容 展示 区 ) 文件 传递 参数 ， 其 关键 代码 如 下 : 

Pp 语句 ， 判 断 conn_id 的 值 是 否 与 case 关键 字 中 指定 的 值 相同 ， 如 果 相同 ， 则 执行 相应 的 操作 


#/ 
switch($_GET[conn id]){ 


ease "20510111": // 指 定 关键 字 
include ‘accidence.php'; // 包 含 文件 
S$smarty->assign('phtml','accidence.html'); // 将 模板 文件 的 名 称 赋 给 模板 变量 


/通过 seript 脚本 向 指定 的 文件 中 传递 参数 
echo "<script>parent topwindow .location href='pd_top.php?conn_id=20510111';</script>"; 
echo "<script>parentmainwindow ,location href='pd_main.php? conn_id=20510111';</seript>"; 
break; // 跳 出 循环 
/省 略 了 部 分 代码 
(2) 通过 Smarty 中 的 include 函数 在 当前 模板 中 包含 其 他 模板 文件 。 
在 switch 语句 中 ， 将 指定 的 模板 文件 名 称 赋 给 一 个 模板 变量 phtml， 此 时 在 内 容 树 状 导航 的 模板 文件 
pd_lefthtml 中 ， 获 取 模 板 变 量 phtml 传递 的 值 ， 并 且 将 该 值 作为 Smarty 中 include 函数 包含 的 模板 文件 。 内 容 


树 状 导航 模板 文件 pd_left.html 的 关键 代码 如 下 : 
<script language="javascript" sre="js/leftjs"></script> 
<link rel="stylesheet" type="text/css" href="css/link.css"></link> 


<div style="width: 10096: height: 10096: padding-left:Spx: padding-top:5px:"> 
{include file=$phtml} 


(3) 通过 Smarty 中 的 注册 模板 函数 读 取 指 定 文件 。 
(4) 通过 Smarty 中 的 count_characters 和 truncate 方法 统计 和 截取 字符 串 。 

在 入 门类 、 开 发 类 和 应 用 类 的 树 状 导航 菜单 中 ， 都 应 用 了 Smarty 中 的 count_ characters 和 truncate 方法 ， 对 
指定 字符 串 的 长 度 进行 统计 和 截取 ， 从 而 判断 数据 属于 几 级 菜单 。count_characters 和 truncate 方法 在 本 项 目 中 
应 用 的 关键 代码 如 下 : 

{if $subject[id12].Slcount_characters—"12" && $subject[id12].Sltruncate:8:""—S$subject[id].8 } 

上 述 代 码 取 自 developer.html 模板 文件 。 

力 设计 过 程 


在 内 容 树 状 导航 概述 中 已 经 了 解 ， 内 容 树 状 导航 除了 包含 pd_ leftphp 和 pd_left.html 文件 外 ， 还 包含 入 门 、 


jy 
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开发 和 应 用 3 类 中 的 6 个 文件 。 

(1) 在 pd_leftphp 文件 中 ,获取 网 站 模块 导航 超 链接 中 传递 的 参数 值 ， 并 且 将 参数 值 赋 给 SESSION 变量 ， 
通过 switch 语句 对 传递 的 参数 值 进行 判断 ， 从 而 控制 框架 中 topwindow〔 网 站 模块 导航 ) 、leftwindow (内 容 树 
状 导 航 》 和 mainwindow〈 内 容 展 示 区 ) 3 部 分 内 容 的 输出 ， 其 关键 代码 如 下 : 


<?php 

session_start(); // 初 始 化 SESSION 变量 

if($_GET[conn_idj—"" and $_GET[table name]—""){ // 判 断 conn_id 和 table_name 的 值 为 空 
$_SESSION[conn id]j="20510111"; /设置 初始 值 

$_SESSION[table_name]="study"; // 设 置 数据 库 名 称 

$_SESSION[class_type]=" 从 零 开 始 "; /设置 功能 模块 

Jelse{ /如 果 不 为 空 ， 则 直接 将 它们 的 值 赋 给 SESSION 变量 


S$_SESSION[conn idj-$_GET[conn id]: 

$_SESSION[table_ name]=$_GET[table_name]: 

$_SESSION[class_type]=$_GET[class_type]: 

} 

require 'system/system.ine.php'; // 包 含 数据 库 连接 、 操 作 方法 和 Smarty 的 配置 方法 
让 


switch 条 件 控制 语句 ， 判 断 conn_id 的 值 是 否 与 case 关键 字 
中 指定 的 值 相 同 ， 如 果 相 同 ， 则 执行 相应 的 操作 

4 

switch($_GET[conn id]){ 


case "20510111": // 指 定 关键 字 
include ‘accidence.php'; /包含 文件 
Ssmarty->assign(phtmlvaceidence html9; // 将 模板 文件 的 名 称 赋 给 模板 变量 
// 通 过 seript 脚本 向 指定 的 文件 中 传递 参数 


echo "<script>parent.topwindow.location.href='pd_top.php?conn_id=20510111';</script>"; 
echo "<script>parent.mainwindow.location. href='pd_main.php?conn_id= 20510111';</script>"; 
break; // 跳 出 循环 
ease "20610111": 
include ‘accidence.php' 
$smarty->assign('phtml','accidence.html); 
echo "<script>parent mainwindow location href='pd_main.php?conn_id= 26010111';</script>"; 
break; 
/| 省略 了 部 分 代码 
default: 
include 'accidence.php'; 
$smarty->assign('phtml','accidence.html"); 
echo "<script>parent.topwindow.location.href='pd_top.php?conn_id=20510111';</script>"; echo 
"<script>try {parent.mainwindow .location.href='pd_main.php?conn_id= 20510111';}catch(e) {}</script>"; 
break; 


} 
Ssmarty->display('pd_left html); /指定 模板 页 
?> 


(2) pd_lefthtml 模板 文件 中 输出 的 内 容 由 switch 语句 中 定义 的 模板 变量 phtml 的 值 决定 ， 在 pd_left.html 
文件 中 应 用 Smarty 中 的 include 函数 包含 由 phtml 指定 的 模板 文件 ， 其 关键 代码 如 下 : 


<script language="javascript" sre="js/left.js"></script> 

<link rel="stylesheet" type="text/ess" href="css/link.css"></link> 

<div style="width: 100%; height: 100%; padding-left:Spx; padding-top:5px:"> 

{include file=$phtml} 

</div> 

(3) 定义 developer.php 文件 ， 获 取 SESSION 变量 中 传递 的 值 ， 执 行 查 询 操 作 ， 并 将 查询 结果 赋 给 指定 的 

模板 变量 ， 注 册 模 板 函 数 ， 读 取 指定 的 文件 ， 其 代码 如 下 : 

<?php 


i($_SESSION[conn_id] 一 "" and $_SESSION[table_name] 一 ""){ ”// 判 断 SESSION 变量 的 值 是 否 为 空 

Sconn_id="10127105"; // 如 果 SESSION 变量 的 值 为 空 ， 则 直接 为 变量 赋值 
Stable_name="ymzx": 

Sclass_type=" 源 码 管理 "; 

yelse{ /如 SESSION 变量 不 为 空 ， 将 SESSION 的 值 赋 给 指定 的 变量 
S$conn_id=$_SESSION[conn id]: 

Stable_name=$_SESSION[table_name]: 

Sclass_type=$_SESSION[class_type]: 

} 


S$smarty->assign("conn_id",$conn id): /设置 模板 变量 
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$smarty->assign("class type",$class_type): /设置 模板 变量 
function unHtml($params) { 1/ 创建 自 定义 函数 
extract($params):; // 将 数组 中 的 数据 转换 到 变量 中 
if(strlen($text)—12){ // 判 断 字符 串 的 长 度 是 否 等 于 12 
S$str =is_file("files/". $text.".htm"); 1/ 判断 指定 的 文件 是 否 存在 
Sstrl =is_file("files/". $text.".exe"); // 判 断 指定 的 文件 是 否 存在 
if(Sst){ // 如 果 文件 存在 
return "files/" $text.".htm"; // 返 回 文件 名 称 
yelse if($strD){ 
retum "files/" .$text.".exe"; /返回 文件 名 称 
jelsef 
return "files/1999.htm"; // 否 则 返回 一 个 新 的 文件 
. 
jelse if(strlen($text)—16){ // 判 断 字符 串 的 长 度 是 否 等 于 16 
Sstr =is_file("files/".$text.".htm"); // 判 断 指定 的 文件 是 否 存在 
if(Sst){ 
return "files/". $text.".htm"; /返回 文件 名 称 
jelseifSstrD{ 
Tetumn "files/" $text.".exe"; /返回 文件 名 称 
jelsef 
return "files/2000.htm"; /否则 返回 一 个 新 的 文件 
} 
, } 
$smarty->register_function("Util", "unHtml"); /注册 模板 函数 
if($conn_id 一 "10121002@10122105@10123105@10125105"){ 。 /判断 变量 的 值 
Sarray_id=explode("@",$conn_id); // 将 这 值 返回 到 数组 中 
Sarray_table=explode("@",$table_name); // 将 数据 表 名 称 的 值 返 回 到 数组 中 
for($i=0;$i<count($array_id):$i++){ /| 循环 读 取 数组 中 的 id 值 
// 执 行 查询 操作 
Srst[$i] = Sadmindb->ExecSQL("select * from $array_table[$i] where xxbh like ‘$array_id[$i]%",$conn); 
Sresult=array_merge($rst[0].Srst[1].$rst[2].$rst[3]): // 合 并 查询 结果 
S$smarty->assign('subject', $result); // 将 合并 的 查询 结果 赋 给 模板 变量 
jelsef 
/执行 查询 操作 
Srst = $admindb->ExecSQL("select * from $table_name where xxbh like 'Sconn id9o",Sconn): 
S$smarty->assign('subject',$rst); /| 将 查询 结果 赋 给 模板 变量 
> 


(4) 创建 developer.html 模板 文件 ， 通 过 section 循环 语句 读 取 模板 变量 中 存储 的 数据 ， 并 且 应 用 让 语句 进 
行 判断 ， 如 果 指 定 字符 串 的 长 度 是 8 个 字 节 ， 则 说 明 是 一 级 导航 菜单 ; 如 果 指 定 字符 串 的 长 度 是 12 个 字 节 ， 并 
且 其 前 8 个 字 节 与 一 级 导航 菜单 的 8 个 字 节 相同 , 那么 它 是 二 级 导航 菜单 ; 如 果 指 定 字符 串 的 长 度 是 16 个 字 节 ， 
并 且 其 前 8 个 字 节 与 一 级 导航 菜单 的 8 个 字 节 相 同 ， 其 前 12 个 字 节 与 二 级 导航 菜单 的 12 个 字 节 相同 ， 那 么 它 
是 三 级 导航 菜单 。 具 体 代 码 请 参考 光盘 中 内 容 。 


图 秘笈 心 法 


心 法 领悟 494: 使 用 pd_left.html 模板 文件 的 注意 事项 。 
在 pd_left.html 模板 文件 中 ， 必 须 载 入 leftjs 脚本 文件 和 link.css 样式 文件 ， 这 是 实现 树 状 导航 菜单 功能 和 
控制 页 面 属性 的 关键。 


实例 495 


趣味 指数 : 伍 食 福全 | 


力 实例 说 明 
内 容 展示 区 可 输出 内 容 树 状 导航 菜单 中 指定 标题 的 完整 内 容 。 如 果 指 定 标题 的 完整 内 容 不 存在 ， 则 输出 指 
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定 的 蔡 代 文件 ， 其 运行 效果 如 图 10.35 所 示 。 


入 门 开发 应 用 


四 人 要 Fi 


i 让 4 
昌国 册 囊 了解 ( 讽 频 ) 程序 员 的 工作 
《加 ts 程序 是 由 算法 、 站 各 序 设计 方法 、 计 算 机 本 寺 工 具 环 光度 ,我 们 全 从 事 程序 开 恬 、 维 护 的 专业 人 员 ， 从 为 程序 


设计 人 员 的 分 析 总 结 的 开发 方案 ， 来 编 

向 题 ， 程序 员 进 行 沟通 ， 来 修改 程序 ， 当 测试 通过 

步 的 成 果 。 ede 程序 员 完 成 的 工作 在 整 人 软件 开 发 过 得 中 起 兰 关 键 上 的 作用 ， 也 
ee 纺 S 人 RR. Te 下 面 是 一 个 软件 开发 的 流程 图 。 


~ 


员 。 在 开发 项 目 之 1 


一 个 简单 的 程序 实现 
日 国 了 解 开发 相关 的 几 个 | 
所 国生 序 员 的 成 上 之 路 


rs 
© 
mm / 
国 we miaf 卉 
[BB 
[ET a 
日 国 _m5 0 向 动 全 人 
国庆 过 开 几 芝 香 有 动 
日 国 wh 60 的 昌吉 开发 环 1 Rn 
EE | eo 


《全 入 记 由》 是 红字 习 的 者 帮 、 持 太 查 二 的 工具 、 也 动 与 灾 运 的 吉方 。 内 罕 胡 六 技术 、 项 目 、 方 案 、 神 码 ， 视 频 、 略 而 等 考 而 。 


图 10.35 内 容 展示 | 


内 


图 关键 技术 


内 容 展 示 区 中 完整 内 容 的 输出 ， 关 键 是 内 容 树 状 导航 菜单 中 标题 的 超 链接 值 的 设置 ， 该 值 是 从 注册 模板 函 
数 中 获取 的 。 也 就 是 说 在 注册 模板 函数 中 判断 指定 标题 的 完整 文件 是 否 存 在 ， 如 果 存 在 ， 则 输出 这 个 文件 ， 否 
则 输出 指定 的 蔡 代 文件 。 在 本 项 目 中 定义 3 个 注册 模板 函数 ， 其 功能 都 是 输出 指定 的 文件 ， 这 3 个 模板 文件 分 
别 存储 于 accidence.php、criterion.php 和 developer.php 中 。 


力 设计 过 程 
内 容 展示 区 只 包含 一 个 文件 pd_main php。 在 该 文件 中 判断 超 链 接 传递 的 参数 值 ， 并 根据 此 数值 包含 不 同 的 
替代 文件 ， 其 代码 如 下 : 


<?php 

//require_once 'system/system_inc.php': // 调 用 配置 文件 
JSsmarty->assign('conn_id'$_GET[conn id]): 

这 $_GET[conn id] 一 "20510111" or $_GET[conn_id]j="10121605"){ 。”// 判 断 超 链 接 的 id 值 


include_once("files/1999.htm"): /调用 指定 的 包含 文件 
}else{ 

include_once("files/2000.htm"): // 调 用 指定 的 包含 文件 
} 

> 


图 秘笈 心 法 

心 法 领悟 495: 关于 JavaScript。 

在 “明日 编程 词典 一 一 在 线 体验 版 ” 的 页 面 设计 中 应 用 了 很 多 JavaScript 代码 ， 其 中 包括 对 导航 栏 和 树 状 导 
航 栏 的 设计 。 如 比较 流行 的 JQuery 框架 即 是 业界 追捧 的 JavaScript 框架 ， 如 果 用 户 有 JavaScript 脚本 语言 的 基 
础 ， 可 以 利用 JQuery 框架 实现 本 实例 的 内 容 。 


PHP 开发 实例 大 全 (基础 卷 ) 


10.4 SQL Server 数据 库 的 安全 与 维护 
一 本 wo 
ri 1 
实例 
i | eed 
力 实例 说 明 
数据 库 在 使 用 一 段 时 间 后 ， 时 常会 出 现 因 删 除数 据 而 造成 的 空闲 空间 太 多 的 情况 ， aaa 
数据 库 文件 和 事务 日 志文 件 的 空间 ， 以 免 浪 费 磁盘 空间 。 当 
数据 库 中 没有 数据 时 , 可 以 直接 修改 数据 库 文件 的 属性 以 改 
变 其 占用 空间 ,但 当 数 据 库 中 有 数据 时 ， 这 样 操作 就 会 破坏 


其 中 的 数据 ， 因 此 需要 使 用 收缩 的 方式 来 缩减 数据 库 空间 。 
本 实例 实现 将 SQL Server 数据 库 | 的 未 使 用 空间 缩 为 服 查 王 hc-201905101638 GD se 51) |ab-astabasel0 | 0:00:00 有 行 了 硬 1 列 了 弦 才 


数据 库 大 小 的 10%。 在 查询 分 析 器 中 的 运行 结果 如 图 10.36 图 10.36 收缩 数据 和 日 志 
所 示 。 
图 关键 技术 


可 以 使 用 DBCC SHRINKDATABASE 命令 来 压缩 数据 库 。 
DBCC SHRINKDATABASE 语句 的 语法 如 下 : 
DBCC SHRINKDATABASE 
(database name [ , target_percent ] 
[,{NOTRUNCATE | TRUNCATEONLY } ] 
) 
参数 说 明 : 
database_name: 要 压缩 的 数据 库 名 称 。 
target_percent: 数据 库 压缩 后 ， 数 据 库 文件 中 所 要 的 剩余 可 用 空间 百分比 。 如 果 指 定 的 百分比 过 大 ， 超 过 
了 压缩 前 未 使 用 的 空间 所 占 的 比例 ， 则 数据 库 不 会 被 压缩 。 另 外 ， 压 缩 后 的 数据 库 不 能 比 数据 库 初 使 设 定 的 容 
量 小 。 
NOTRUNCATE: 在 数据 库 文件 中 保留 所 释放 的 文件 空间 。 如 果 未 指定 ， 将 释放 的 文件 空间 分 配给 操作 系统 。 
TRUNCATEONLY: 将 数据 库 文件 中 的 任何 未 使 用 的 空间 释放 给 操作 系统 ， 并 将 文件 收缩 到 上 一 次 所 分 配 
的 大 小 ， 从 而 减 小 文件 而 不 移动 任何 数据 ， 不 试图 重新 定位 未 分 配 页 的 行 。 选 择 此 项 后 ，target_percent 选项 将 
无 效 。 


国 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 


(2) 在 查询 分 析 器 中 选择 要 连接 的 数据 库 为 db_database10。 
(3) 在 代码 编辑 区 中 输入 SQL 语句 : 


DBCC SHRINKDATABASE (model, 10) 

(4) 单 击 执行 按钮 时 ， 执 行 本 实例 ， 即 可 将 数据 库 压 缩 。 
国 秘笈 心 法 

心 法 领悟 496: 压缩 数据 库 。 
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数据 库 的 负载 越 大 ， 其 运行 速度 就 越 慢 。 读 者 以 后 的 就 业 取向 可 能 是 PHP 程序 员 ， 而 对 于 数据 库 的 优化 ， 
取得 高 效 的 运行 速度 应 该 是 一 位 合格 的 程序 员 所 必 备 的 技术 。 压 缩 数 据 库 就 是 如 何 优化 数据 库 速度 的 第 一 课 。 


高 级 
趣味 指数 : 三 机 页 机 


实例 497 


力 实例 说 明 


其 查询 光 成 。 。 [RC-201005101839 BD) ss Gl) msster |0.00:01 R 订 行 1 到 1 


图 10.37 ”收缩 数据 和 日 志 


力 关键 技术 
使 用 DBCC SHRINKFILE 命令 收缩 相关 数据 库 的 指定 数据 文件 或 日 志文 件 大 小 ， 语 法 如 下 : 


DBCC SHRINKFILE 
( {file_name | file_id } 
{[, target_size ] 
|[. {EMPTYFILE | NOTRUNCATE | TRUNCATEONLY } ] 
} 


) 

参数 说 明 : 

file_ name: 已 收缩 文件 的 逻辑 名 称 。 

file_id: 要 收缩 文件 的 标识 (ID) 号 。 如 要 获得 文件 的 了 D, 请 使 用 FILE ID 函数 或 在 当前 数据 库 中 搜索 sysfiles。 

target_size: 指定 文件 收缩 后 的 大 小 , 以 MB 为 单位 。 如 果 不 指定 此 选项 , SQL Server 将 最 大 限度 地 缩减 文件 。 

EMPTYFILE: 指明 文件 不 再 使 用 ,将 所 有 此 文件 中 的 数据 移动 到 同一 文件 组 中 的 其 他 文件 中 去 。 执 行 此 命 
令 后 ， 此 文件 就 可 以 用 ALTER DATABASE 语句 删除 了 。 

参数 NOTRUNCATE 和 TRUNCATEONLY 与 DBCC SHRINKDATABASE 命令 中 的 含义 相同 , 请 读者 参见 
实例 496， 这 里 不 再 效 述 。 


力 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 


“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


USE master 


SELECT FILE_ID(master’) 
DBCC SHRINKFILE (1. 7) 
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(3) 单 击 执行 按钮 ”， 执 行 本 实例 ， 即 可 实现 数据 的 收缩 。 


国 秘笈 心 法 


心 法 领悟 497: 收缩 数据 与 压缩 数据 。 
在 笔者 看 来 ， 收 缩 数据 与 压缩 数据 在 功能 上 没有 什么 不 同 。 压 缩 数据 是 按 比 例 将 数据 的 物理 内 存 减 小 ， 而 
收缩 数据 是 根据 传 入 参数 将 数据 文件 的 大 小 减少 至 一 定 值 。 


实例 498 


力 实例 说 明 
在 网 站 开发 过 程 中 ， 


: 
i 


高 
趣味 指教 : 傅 博 二 禄 ; 


数据 库 一 般 都 保存 有 许多 重要 的 数据 信息 ， 这 些 数 据 的 丢失 将 会 带 来 很 严重 的 后 果 ， 


所 以 对 系统 数据 库 进行 备份 非常 重要 ， 这 样 可 以 在 数据 库 出 现 错 误 时 能 够 及 时 地 恢复 数据 库 。 本 实例 介绍 使 用 
SQL 语句 备份 SQL Server 数据 库 的 过 程 ， 并 使 SQL Server 在 完成 备份 的 20% 时 显示 备份 进度 信息 。 


图 关键 技术 


本 实例 使 用 BACKUP DATABASE 语句 ， 完 成 数据 库 、 差 异 式 或 文件 和 文件 组 的 备份 ， 其 简要 用 法 如 下 : 
BACKUP DATABASE { database_name | @database_name_var } 
TO < backup device >[ ,.n] 


[WITH 


[BLOCKSIZE = { blocksize | @blocksize_variable } ] 
[[,]NAME = { backup_set_name | @backup_set_name var } ] 


[[,] DESCRIPTION = 

] DIFFERENTIAL ] 
FORMAT | NOFORMAT ] 
{NOUNLOAD | UNLOAD } ] 


[[, 
[[,] 
[[,] 
[[,]RESTART] 
[IT.1 


{ text | @text_variable } ] 


STATS[=percentage 11 


BACKUP DATABASE 语句 参数 说 明 如 表 10.2 所 示 。 


表 10.2 BACKUP DATABASE 语句 的 参数 说 明 


参数 说 明 
设置 写 入 时 的 数据 区 块 大 小 。 此 值 通常 不 需 设置 ， 可 以 由 SQL Server 自行 决定 ， 但 如 要 将 备份 
BLOCKSIZE 数据 库 刻 录 到 光盘 上 ， 并 打算 用 光盘 进行 还 原 ， 则 需 将 此 值 设置 为 2048。 如 要 指定 磁盘 的 数据 
区 块 大 小 ， 必 须 搭配 FORMAT 参数 使 用 
NAME 表示 备份 结果 集 的 名 称 ， 其 长 度 不 超过 128 个 字符 
DESCRIPTION 描述 备份 设置 的 文本 ， 最 多 包括 255 个 字符 
表示 仅 备份 上 次 进行 完整 数据 库 备 份 以 来 数据 所 发 生 的 变化 ， 即 进行 差异 备份 。 差 异 备份 一 般 
DIFFERENTIAL 比 完整 备份 占用 更 少 的 空间 。 对 于 上 一 次 完整 备份 时 备份 的 全 部 单个 日 志 ， 使 用 该 选项 可 以 不 
必 再 进行 备份 
FORMATINOFORMAT | 设置 是 否 先 格式 化 磁盘 
NOUNLOADIUNLOAD | 设置 是 否 要 在 备份 完成 时 退出 磁盘 
指定 SQL Server 重新 启动 一 个 被 中 断 的 备份 操作 。 因 为 RESTART 选项 在 备份 操作 中 断 处 重新 
RESTART 启动 该 操作 ， 所 以 节省 了 时 间 。 若 要 重新 启动 一 个 特定 的 备份 操作 ， 要 重复 整个 BACKUP 语 
名 并 且 加 入 RESTART 选项 。 不 一 定 非 要 使 用 RESTART 选项 ， 但 它 具有 节省 时 间 的 优势 
STATS 表示 在 备份 完 某 一 百分比 数据 之 后 所 要 显示 的 信息 


第 10 章 PHP 操作 SQL Server 数据 库 


力 设计 过 程 


下 面 将 备份 db_database10 数据 库 ， 具 体操 作 步 又 如 下 : 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


BACKUP DATABASE db sql 
TO disk=E:MyDatadb sql 备份 -bak 


(3) 单 击 执行 按钮 站 ， 执 行 备份 。 备 份 后 的 db_database10 数据 
库 被 保存 在 E 盘 的 SQL Server Data 文件 夹 中 ， 如 图 10.38 所 示 。 


国 秘笈 心 法 图 10.38 备份 数据 库 文件 


心 法 领悟 498: 备份 数据 库 的 注意 事项 。 
笔者 在 讲解 MySQL 数据 库 备 份 时 已 经 说 过 ， 备 份 出 来 的 文件 虽然 已 经 经 过 加 密 处 理 ， 但 也 是 将 数据 信息 
以 近乎 明文 的 方式 展现 给 用 户 ， 存 在 一 定 的 风险 。 


oo 人 一 一 一 | 
9 趣味 指数 : 寅 让 福全 | 
图 实例 说 明 


本 实例 实现 的 是 在 创建 的 命名 备份 设备 上 创建 db_database10 数据 库 的 事务 日 志 备份 。 事 务 日 志 备份 仅 制作 日 志 
文件 的 复 本 。 日 志文 件 备份 本 身 不 能 用 于 还 原 数据 库 。 日 志文 件 在 数据 库 还 原 后 ， 可 将 数据 库 恢复 到 原始 的 故障 点 。 


图 关键 技术 


本 实例 应 用 的 技术 有 创建 备份 设备 和 应 用 BACKUP BLOG 语句 备份 事务 日 志 。 

1. 创建 备份 设备 

备份 设备 是 创建 备份 和 恢复 数据 库 的 前 提 条 件 ， 可 以 将 数据 库 、 事 务 日 志和 文件 备份 到 磁盘 和 磁带 上 。 设 
备 可 以 分 为 4 种 : 磁盘 设备 、 磁 带 设备 、 物 理 设 备 和 逻辑 设备 。 

磁盘 设备 、 磁 带 设备 和 物理 设备 在 备份 时 ， 只 要 选择 相应 的 设备 即 可 。 而 逻辑 设备 用 来 标识 物理 设备 的 别 
名 或 公用 名 称 ， 其 名 称 永久 地 存储 在 SQL Server 内 的 系统 表 中 。 使 用 逻辑 备份 的 优点 是 引用 名 称 简单 ， 例 如 ， 
逻辑 设备 名 称 可 以 是 mrsoft Backupfdw， 而 物理 设备 名 称 则 是 E:\SQL Server DatawmrosftMyBackup.bak。 


在 Transact-SQL 语句 中 ， 使 用 op - addumpdevice 系统 存储 过 程 创 建 备份 设备 ， 语 法 如 下 : 
sp_addumpdevice [ @devtype = ] ‘devict 
[ @logicalname = ] logical_ name' 、 
[ @physicalname = ] ‘physical_name’ 
[, {[ @entrltype = ] controller type 
|[ @devstatus = ] 'device_status' 


参数 说 明 ; 

device type: 备份 设备 的 类 型 。device_type 的 数据 类 型 为 varchar(20)， 没 有 默认 设置 ， 可 以 是 Disk〔 硬 盘 
文件 ) 、Pipe〈 命 名 管理 ) 或 Tape (磁带 设备 ) 。 

logicalname: 备份 设备 的 逻辑 名 称 , 该 逻辑 名 称 用 于 BACKUP 和 RESTORE 语句 中 , 其 数据 类 型 为 sysname， 
没有 默认 值 ， 并 且 不 能 为 NULL。 

physicalname: 备份 设备 的 物理 名 称 。 物 理 名 称 必须 遵照 操作 系统 文件 名 称 的 规则 或 者 网 络 设备 的 通用 命名 
规则 ， 并 且 必 须 包括 完整 的 路 径 。physical_name 的 数据 类 型 为 nvarchar(260)， 没 有 默认 值 并 且 不 能 为 NULL。 
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2. 用 BACKUP LOG 语句 备份 事务 日 志 

执行 BACKUP LOG 语句 备份 事务 日 志 ， 同 时 指定 要 备份 的 事务 日 志 所 属 的 数据 库 名 称 、 事 务 日 志 备份 将 
写 入 的 备份 设备 。 其 语法 格式 请 参见 实例 498 中 的 技术 分 析 。 

执行 完整 数据 库 备 份 或 差异 数据 备份 期 间 不 能 备份 事务 日 志 , 但 在 运行 文件 备份 的 同时 可 以 备份 事务 日 志 。 
另外 ， 下 列 情况 不 要 备份 事务 日 志 : 

(1) 在 由 于 事务 日 志 包 含 自 上 次 创建 备份 后 数据 库 所 发 生 的 更 改 ， 而 创建 了 数据 库 或 文件 备份 之 前 。 

(2) 事务 日 志 已 被 截断 。 此 时 如 果 要 备份 事务 日 志 ， 必 须 先 创建 数据 或 差异 数据 库 备 份 。 


图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 


(2) 在 代码 编辑 区 中 输入 SQL 语句 ， 创 建 一 个 名 为 mrsoft_Backupfdw 的 逻辑 磁盘 设备 ， 其 物理 路 径 为 


E:\SQL Server Data\mrosft\MyBackup.bak. 
SP_ADDUMPDEVICE 'disk',mrsoft_ Backupfdw’,' E:\SQL Server Data\mrosft\MyBackup.bak ' 


(3) 单 击 执行 按钮 ”， 执 行 本 实例 ， 其 运行 结果 如 图 10.39 所 示 。 
(4) 在 代码 编辑 区 中 输入 如 下 SQL 语句 ， 用 来 在 创建 的 命名 备份 设备 mrsoft_Backupfdw 上 创建 db_ 
database10 数据 库 的 事务 日 志 备份 。 


BACKUP LOG db_database10 
TO mrsoft_Backupfdw 
GO 


(5) 单 击 执行 按钮 》”， 执 行 本 实例 ， 其 运行 结果 如 图 10.40 所 示 。 


BE 习 
埋 朋 设备 已 lt 
dl EE 


Ee EE 
和 i 0 ud [96600 抹 阿 11 旭 里 妥 
10.39 创建 备份 设备 图 10.40 事务 日 志 备份 
图 秘笈 心 法 


E 


心 法 领悟 499: SQL Server 备份 事务 日 志 的 注意 事项 。 
在 SQL Server 中 备份 db_database10 数据 库 事务 日 志 的 过 程 中 ， 首 先 选 择 数据 库 的 故障 还 原 模式 ， 如 选择 
“完全 ”模式 ， 然 后 单 击 “ 确 定 ” 按 钮 ， 如 图 10.41 所 示 。 


wa Im | sa96 lzne ws em | 


La [5 77 | 


= 
图 10.41 db_database10 数据 库 故 障 还 原 模式 
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实例 500 


趣味 指数 : 走 相 页 页 ， 


力 实例 说 明 


本 实例 首先 备份 一 个 名 为 db_database10 的 数据 库 , 然后 检查 该 数据 库 备 份 集 是 否 完整 以 及 所 有 卷 是 否 都 可 
读 。 在 查询 分 析 器 中 的 运行 结果 如 图 10.42 所 示 。 


e000 BO Re ED bute [90m 0 厂 后 4 开本 志 


图 10.42 检查 备份 集 


图 关键 技术 


本 实例 主要 应 用 RESTORE VERIFYONLY 语句 检查 数据 库 备 份 集 是 否 有 效 ， 其 语法 如 下 : 
RESTORE VERIFYONLY 
FROM < backup device>[,...n] 
[WITH 
[FILE = fle_number 
[[;] {NOUNLOAD|UNLOAD}] 
[[;]LOADHISTORY ] 
[[,] PASSWORD = { password | @password_variable } ] 
[[ 
[[ 


backup_device: 指定 还 原 时 要 使 用 的 逻辑 或 物理 备份 设备 。 
FILE = file_ number: 标识 要 还 原 或 处 理 的 备份 集 。 例 如 ，file number 为 1 表示 第 1 个 备份 集 ，file_number 
为 2 表示 第 2 个 备份 集 。 如 果 没 有 指定 file_number， 则 假定 是 指定 <backup_device> 上 的 第 1 个 备份 集 。 
图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 


“SQL Server 身份 验证 ”选项 ， 登 录 名 为 saa， 密码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


backup database db_database10 
to disk='E:\SQL Server Datafdw bak' 


ae verifyonly from disk=E:\SQL Server Data\fdw.bak’ 
“G3) 单 击 执行 按钮 》”， 执 行 本 实例 ， 其 运行 结果 如 图 10.42 所 示 。 
国 秘笈 心 法 
心 法 领悟 500: 检查 备份 集 的 相关 事项 。 
RESTORE VERIFYONLY 语句 用 来 验证 备份 但 不 还 原 备 份 ， 它 检查 备份 集 是 否 完整 以 及 所 有 卷 是 否 都 可 
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读 , 但 不 尝试 验证 备份 卷 中 的 数据 结构 。 如 果 备 份 有 效 ， 则 在 SQL Server 2000 中 返回 此 消息 : “备份 集 有 效 ”。 


力 实例 说 明 


本 实例 实现 定时 备份 数据 库 ， 并 使 SQL Server 在 备份 完成 20% 时 显示 备份 进度 信息 。 在 查询 分 析 器 中 的 运 
行 结果 如 图 10.43 所 示 。 


到 

总 5 部 这 上 页 属 二 物 枯 库 “gb_databaxsl10” 的 文件 " 册 _detabase10_Datz” (位 于 文件 ! 上 ) 。 

下 人 于 了 害 数 扫 库 ， 生 dxr wsselg 的 文件 “ob_databazslo Log (位 于 文件 1 上 ) ， 
eT 


js 


Han. ea 0 eB ee 00700 0 而 1, 列 人 0 


图 10.43 定时 备份 数据 库 


力 关键 技术 


本 实例 主要 应 用 转换 函数 CONVERT 实现 。 在 将 datetime 数据 转换 为 char 或 varchar 数据 时 ，CONVERT 
的 style 参数 提供 了 各 种 日 期 显示 格式 。 年份 可 以 显示 为 两 位 或 四 位 数 。 默 认 情况 下 ，SQL Server 将 年 份 显示 为 
两 位 数 ， 若 要 显示 包括 世纪 的 四 位 数 年 份 即 使 年 份 数据 是 使 用 两 位 数 的 年 份 格式 存储 的 ) ， 给 style 值 加 100 
即 可 。 
图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 
declare @filename varchar(1000) 
人 


backup database db_database10 
to disk = @filename with stats=20 


(3) 单 击 执行 按钮 ”， 执 行 本 : 


10.44 ”本 实例 的 实现 过 程 


国 秘 稚 心 ; 
心 法 领悟 501: 用 style 参数 转换 日 期 。 
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用 style 参数 转换 日 期 的 语句 如 下 : 


SELECT CONVERT(char(12).GETDATEQ.3) 


此 语句 把 当前 日 期 转换 为 样式 3， 即 ddimmy/yy。 


| 


实例 502 


力 实例 说 明 


本 实例 实现 对 db_database10 数据 库 tb_demo1l1 用 户 信 息 表 中 的 用 户 
名 和 密码 进行 加 密 。 注意 , 在 通过 pwdencryptO 函 数 对 相同 的 用 户 名 和 密 
码 进行 加 密 后 ， 生 成 的 结果 不 相同 并 且 是 不 可 逆 的 。 本 实例 的 运行 结果 
如 图 10.45 所 示 。 Tp ne op Porm 


宵 息 


De pe] 
本 实例 主要 应 用 加 密 函 数 pwdencrypt0 和 加 密 校 验 函 数 pwdcompare0 ec-2ni0 ls 51 hatweea0 | 00 0 行 队 8, 列 本 局 
实现 。 图 10.45 ”对 数据 库 中 的 数据 进行 加 密 


图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 


“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 


(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


declare @User varchar(100),@Password varchar(100) 
select @User='mrfdw'\@Password="mrgwh’ 

--Insert 插入 

insert into dbo.tb_demol1 (UP_Name.Up_Password) 
select 


@User.convert(varbinary(256),pwdencrypt(@Password)) 
--Select 查询 

Select * from tb_ demoll 

where Up_Name=@User 

and pwdcompare(@Password,Up_Password)=1 


(3) 单 击 执行 按钮 ， 执 行 本 实例 ， 其 实现 的 结果 如 图 10.45 所 示 。 
秘笈 心 法 


心 法 领悟 502: 加 密 函 数 pwdencryptO。 
由 于 此 函数 对 插入 的 相同 数据 进行 加 密 后 ， 生 成 的 结果 不 相同 而 且 不 可 逆 ， 是 一 种 非常 安全 的 加 密 手段 ， 
被 广泛 应 用 。 


.的 分 离 和 附加 商 弘 


国 实例 说 明 


为 了 方便 读者 运行 和 学 习 本 章 实例 内 容 ， 避 免 出 现 不 必要 的 操作 失误 ， 特 向 读者 介绍 一 些 操作 SQL Server 
数据 库 的 细节 内 容 。 本 实例 主要 讲解 如 何 分 离 、 附 加 数据 库 。 
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图 关键 技术 


分 离 数 据 库 : 将 数据 库 从 SQL Server 数据 库 中 分 离 出 来 以 复制 数据 库 文件 。 已 分 离 的 数据 库 将 无 法 使 用 ， 
除非 再 次 将 其 附加 到 SQL Server 中 。 
附加 数据 库 : 是 相对 于 分 离 数 据 库 而 言 的 ， 当 数据 库 文件 被 分 离 后 ， 重 新 载 入 到 数据 库 中 。 


图 设计 过 程 


(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 企 业 管 理 器 ”命令 ， 启 动 企业 管理 器 。 

(2) 选中 指定 的 数据 库 ， 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “所 有 任务 ”/“ 分 离 数 据 库 ” 命令 ， 如 图 10.46 所 示 。 

(3) 附加 数据 库 。 选 中 “数据 库 ” 选 项 ， 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “所 有 任务 ”/“ 附 加 数据 库 ” 
命令 ， 如 图 1 


图 10.46 分 离 数据 库 图 10.47 ”附加 数据 库 


图 秘笈 心 ; 
心 法 领悟 503: SQL Server 数据 库 的 附加 。 


如 果 要 将 其 他 计算 机 上 的 数据 库 文 件 转 到 用 户 机 上 , 可 以 在 SQL Server 安装 路 径 的 Date 文件 夹 下 复制 或 前 
切 该 数据 库 文件 ， 然 后 将 其 粘贴 到 用 户 机 SQL Server 安装 路 径 的 Date 文件 夹 中 ， 随 即 附加 数据 库 即 可 。 


库 导 出 数据 至 Excel 表 中 高 级 
国 实例 说 明 
Excel 是 集 数据 统计 、 数 据 分 析 、 图 表 制 作 、 打 印 等 功能 于 一 体 的 专业 电子 表格 软件 ， 可 以 将 数据 导出 至 


Excel 中 进行 各 种 处 理 。 本 实例 讲解 将 SQL Server 中 db_database10 数据 库 中 的 数据 表 tb_demo10 的 数据 导出 到 
Excel (tb_demo10.xls) 文件 中 的 方法 ， 运 行 结果 如 图 10.48 所 示 。 


cl — tb_iasalal -I9 
EE 
二 数 丘 四。 天 口中 再 助 中 -ex 
Ed 加 


i B 和 
工 《PHP 开 发 实战 宝 78 元 站 48 
2 《PHP 标 准 教程 六 79 元 


3 人 编程 宝 73 元 8 和 村 
四 


图 10.48 Excel (tb_demo10.xls) 文件 中 的 数据 


第 10 章 PHP 操作 SQL Server 数据 库 


力 关键 技术 


本 实例 主要 应 用 xp_cmdshell 函数 和 bcp 实用 工具 实现 功能 。 

(1) xp_cmdshell 函数 

xp_cmdshell， 以 操作 系统 命令 行 解释 器 的 方式 执行 给 定 的 命令 字符 串 ， 并 以 文本 行 方式 返回 任何 输出 ， 其 
语法 如 下 : 

xp_cmdshell {command string’} [, no_output] 

参数 说 明 : 

'command string': 在 操作 系统 命令 行 解释 器 上 执行 的 命令 字符 串 。command string 的 数据 类 型 为 
varchar(255) 或 nvarchar(4000), 没有 默认 值 。command string 不 能 包含 一 对 以 上 的 双 引 号 ， 如 果 所 引用 的 文件 
路 径 或 程序 名 称 中 有 空格 ， 则 需要 使 用 一 对 引号 。 

no_output: 可 选 参数 ， 表 示 执 行 给 定 的 command_string， 但 不 向 客户 端 返回 任何 输出 。 

返回 代码 值 : 0 (成 功 ) 或 1 (失败 ) 。 

(2) bcp 实用 工具 

bcp 实用 工具 是 一 种 命令 提示 符 大 容量 复制 的 实用 工具 ， 它 以 用 户 指定 的 格式 从 操作 系统 文件 或 向 操作 系 
统 文件 复制 。 下 面 以 bcp 实用 工具 用 于 SQL Server 2000 实例 和 数据 文件 之 间 指 定 的 格式 复制 数据 为 例 ， 介 绍 
bcp 实用 工具 中 几 个 重要 的 参数 。 

加 ”Injoutlqueryoutlformat: 指定 大 容量 复制 的 方向 。In 是 指 从 文件 复制 到 数据 库 表 或 视图 ，out 是 指 从 数 
据 库 表 或 视图 复制 到 文件 。 

-c: 使 用 字符 数据 类 型 执行 大 容量 复制 操作 。 

-q: 在 bcp 实用 工具 和 SQL Server 实例 的 连接 中 执行 SET QUOTED_IDENTIFLERSON 语句 。 
-S server name[/instance name]: 指定 要 连接 的 SQL Server 实例 。 

-U login_id: 指定 用 于 连接 的 SQL Server 实例 。 

-P password: 指定 登录 ID 的 密码 。 


图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 


“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 
(2) 在 代码 编辑 区 中 输入 SQL 语句 : 


EXEC master..xp_cmdshell bcp db_database10.dbo tb_demol0 out E:\tb_demol0.xls -¢ -q -S"localhost" 
-U"sa" -P" 


(3) 单 击 执行 按钮 上， 执行 本 实例 ， 其 运行 结果 如 图 10.49 所 示 。 


办 办 办 办 


数据 包 的 大 小 〔 字 节 ) : 4096 
时 捉 时 间 【 训 种) : 共 3 
TEL 


口 Rs 国 浊 s 
本 000101639 的 中 [a 5 Paster | Do cid 和 5 行 硬 8 列 1 | 


10.49 从 SQL Server 数据 库 导出 数据 至 Excel 表 中 


国 秘笈 心 法 
心 法 领悟 504: 使 用 xp_cmdshell 函数 的 注意 事项 。 
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xp_cmdshell 以 同步 方式 操作 ， 在 命令 行 解释 器 命令 执行 完毕 之 前 ， 不 会 返回 控制 。 


实例 505 


力 实例 说 明 
本 实例 讲解 将 SQL Server 中 db_database10 数据 库 的 tb_demo10 数据 表 中 的 查询 信息 生成 一 个 存储 到 本 地 EE 
得 的 tb_mrsoft.xls 文件 。 


力 关键 技术 


本 实例 同样 是 应 用 xp_cmdshell 函数 和 bcp 实用 工具 实现 ， 相 关内 容 请 读者 参考 实例 504。 
图 设计 过 程 
(1) 选择 “开始 ”/“ 所 有 程序 ”/Microsoft SQL Server/“ 查 询 分 析 器 ”命令 ， 在 弹出 的 连接 对 话 框 中 选择 
“SQL Server 身份 验证 ”选项 ， 登 录 名 为 sa， 密 码 为 空 。 
(2) 在 查询 分 析 器 中 选择 要 连接 的 数据 库 为 db_database10。 
(3) 在 代码 编辑 区 中 输入 SQL 语句 : 
declare @sql varchar(1000) 
set @sql ='bep 
"SELECT * FROM db_database10..tb_demo10" 
queryout  E:\SQL Server Data\tb_mrsoft.xls -c -q -S"localhost" 


ee 
EXEC master..xp_cmdshell @sql 


(4) 单 击 执行 按钮 ”， 执 行 本 实例 ， 其 运行 结果 如 图 10.50 所 示 。 
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图 10.50 ”生成 Excel 文件 


图 秘笈 心 法 


心 法 领悟 305: 将 数据 导入 到 Excel 文件 中 。 
将 数据 导入 到 Excel 中 是 程序 员 常 用 的 一 种 数据 统计 方法 ,因为 Excel 中 对 数据 的 求 和 、 排序 等 有 良好 的 支 
持 ， 而 且 将 数据 库 信息 存储 到 Excel 中 也 是 一 种 备份 数据 库 的 方法 ， 只 是 这 种 备份 方法 并 不 常用 。 
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连接 数据 库 

操作 Access 数据 库 
Access 数据 库 的 安全 
Access 数据 库 的 综合 运用 


YY 
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11.1 连接 数据 库 


如 果 开 发 一 个 小 型 网 站 ， 利 用 Access 数据 库 不 仅 方便 操作 、 易 于 维护 ， 更 重要 的 是 可 以 节省 服务 器 资源 ， 
下 面 将 通过 具体 实例 讲解 PHP 操纵 Access 数据 库 的 方法 。 


实例 506 起 叶 指 数 : 雪 南 页 . 
图 实例 说 明 


本 实例 主要 介绍 PHP 如 何 通过 ADO 方式 连接 Access 数据 库 , 效果 如 图 11.1 所 示 , 该 页 面 显示 的 信息 是 从 
Access 数据 库 中 检索 出 来 的 ， 从 而 证 明 通 过 ADO 方式 连接 数据 库 成 功 
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11.1 连接 Access 数据 库 


力 关键 技术 


ADO 技术 基于 通用 对 象 模 型 (COM) ,可 提供 多 种 语言 的 访问 技术 。PHP 是 通过 预先 定义 类 COM 来 使 用 
ADO 方法 操纵 Access 数据 库 的， 该 类 的 详细 说 明 如 下 : 


string com::com( string module name [, string server_name [. int codepage]]) 

参数 说 明 : 

module_name: 被 请 求 组 件 的 名 字 或 class-id。 

server name: DCOM 服务 器 的 名 字 。 

codepage: 指定 用 于 将 PHP 字符 串 转换 成 UNICODE 字符 串 的 代码 页 , 反之 亦 然 。 该 参数 的 取 值 有 CP_ACP、 
CP MACCP, CP OEMCP, CP SYMBOL, CP THREAD ACP、 CP UTF7 和 CP UTF8。 


力 设计 过 程 
(1) 建立 数据 库 连 接 文件 conn php， 实 现 与 Access 数据 库 的 连接 ， 代 码 如 下 : 
<2php 


$conn = new com("adodb.connection"): 
$connstr="driver={microsoft access driver (*.mdb)}: dbq=". realpath("data/db_databasel 1.mdb"); 
$conn->open($connstr); 
?> 
(2) 建立 如 图 11.1 所 示 的 页 面 ， 并 循环 显示 数据 库 中 的 所 有 图 书信 息 ， 代 码 如 下 : 
?php 
$sql="select * from tb_book"; 
S$rs=new com("adodb.recordset"); 
S$rs->open($sql.$conn,1,3): 
while(!$rs->eof) 
全 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo iconv('gbk',"utf-8',$rs->fields(bookname)->value):?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo iconv('gbk',utf-8'.$rs->ficlds(pub)->value):?></div></td> 
<ltr> 
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S$rs->movenext' 


?> 


图 秘笈 心 法 


心 法 领悟 506: ADO 的 相关 了 解 。 

ADO 提供 了 一 个 熟悉 的 、 高 层 的 对 OLE DB 的 Automation 封装 接口 ， 对 那些 熟悉 RDB 的 程序 员 来 说 ， 可 
以 把 OLE DB 比 作 ODBC 的 驱动 程序 。 目 前 ， 虽 然 OLE DB 的 提供 者 较 少 , 但 微软 正 积极 更 新 该 技术 并 打算 用 
OLE DB 取代 ODBC。 


实例 507 


力 实例 说 明 


虽然 Access 是 开发 小 型 项 目的 首选 数据 库 ， 但 是 商家 不 会 因为 项 目 小 而 不 要 求 其 安全 性 ， 所 以 给 Access 
数据 库 设置 密码 是 十 分 必要 的 。 本 实例 通过 ADO 方式 连接 带 密码 的 Access 数据 库 。 当 密码 错误 时 ， 将 显示 如 
11.2 所 示 的 错误 信息 。 
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ODBC Driverscbr/> bYDescription: ¢/b> [licrosoft] [ODBC erosoft Aeccas Driv 
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om-Yopen(" river= (nicroso,.,) 机 [nain} throm in F: Vranpp rasp\ht dace\ RN LL \002\conn Dhp cn 
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11.2 连接 Access 数据 库 密码 错误 


图 关键 技术 
本 实例 实现 连接 带 密码 的 Access 数据 库 的 代码 如 下 : 
<php 


Sconn = new com("adodb.connection"); 
Sconnstr="driver={microsoft access driver (*.mdb)}:Pwd=111: dbq=". realpath("data/db_databasel1.mdb"); 
S$conn->open($connstr); 

ne 


其 关 是 在 ADO 中 时 nd 的 参数 和， 即 Aecens 雪 所 库 的 密友 
图 设计 过 程 

(1) 设置 Access 数据 库 的 密码 与 操作 其 他 数据 库 不 同 ， 必 须 
以 独占 方式 打开 数据 库 。 

(2) 选择 “工具 ” /“ 安 全 ”/“ 设 置 数据 库 密码 ”命令 ， 在 打 
开 的 对 话 框 中 设置 密码 和 确认 密码 ， 如 图 11.3 所 示 。 


(3) 建立 网 页 文件 ， 输 入 如 关键 技术 中 所 示 的 代码 。 如 没有 
任何 输出 ， 表 示 连 接 Access 成 功 。 
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心 法 领悟 507: 取消 或 更 改 Access 数据 库 的 密码 。 
当 用 户 对 Access 数据 库 进 行 维护 时 ， 为 了 方便 性 ， 可 以 暂时 撤销 Access 数据 库 的 密码 ， 方 法 是 : 以 独占 方 
式 打 开 数 据 库 ， 输 入 密码 并 进入 数据 库 ; 选择 “工具 ”/“ 安 全 ”/“ 撤 销 数据 库 密码 ”命令 ， 根 据 提示 再 次 输入 
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图 11.3 设置 并 确认 密码 


PHP 开发 实例 大 全 (基础 卷 ) 
密码 ， 单 击 “ 确 定 ” 按 钮 即 可 。 


11.2 操作 Access 数据 库 


Access 数据 库 是 小 型 项 目 后 台 支 持 的 首选 ， 在 相关 的 数据 库 操作 上 与 其 他 数据 库 有 所 不 同 。 本 节 将 通过 实 
例 详细 介绍 如 何 操作 Access 数据 库 。 


实例 508 高 级 


趣味 指数 : 但 食 食 全 


图 实例 说 明 


本 实例 主要 实现 Access 数据 库 信息 的 查询 。 运 行 本 实例 ， 在 文本 框 中 输入 某 学 生 的 学 号 ， 如 果 查 询 到 该 学 
生 的 成 绩 将 该 学 生 的 详细 成 绩 信息 显示 出 来 ， 如 图 11.4 所 示 。 


0312101 
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图 11.4 通用 数据 信息 查询 


力 关键 技术 


通过 ADO 方式 建立 与 Access 数据 库 的 连接 已 经 在 前 面 介 绍 过 ， 但 建立 完 该 连接 后 并 不 能 对 数据 库 进行 查 
询 、 更 新 等 操作 ， 必 须 先 实例 化 COM 类 建立 记录 集 ， 然 后 通过 open0 方 法 执行 查询 语句 ， 其 关键 代码 如 下 : 


include("conn.php"); // 包 含 数据 库 连接 文件 
S$rs=new com("adodb.recordset"); // 建 立 记录 集 
S$rs->open("select * from tb_score where sno=".$_POST[sno]."".$conn.3,1); /| 执行 查询 
看 设计 过 程 
(1) 新 建 conn.php 文件 ， 建 立 与 Access 数据 库 的 连接 ， 代 码 如 下 : 
<?php 


Sconn=new com("adodb.connection"); 
Sconnstr="provider=microsoftjet.oledb.4.0:data source=".realpath("../data/db_databasel1.mdb");: 
Sconn->open($connstr); 

2> 


(2) 新 建 index.php 文件 ， 创 建 form 表单 ， 将 学 号 提交 到 本 页 ， 在 本 页 中 根据 POST 方法 提交 的 学 号 执行 
查询 操作 ， 查 询 出 符合 条 件 的 数据 并 且 输 出 查询 结果 ， 代 码 如 下 : 


<2php 
if($_POST[submit]!=""){ 
include("conn.php"); 
Srs=new com("adodb.recordset"): 
Srs->open("select * from tb_score where sno=".$_POST[sno].™",$conn,3,1); 
if($rs->eofl| $rs->bob{ 
> 


<tr> 
<td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 没 有 查找 到 该 学 生成 绩 ! </div> </td> 
< 
<2php 
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jelsef 
S$sum=0; 

<tr> 
<td width="170" height="20" bgcolor="#ED9438"><div align="center”> 学 号 </div></td> 
<td width="170" bgcolor="#ED9438"><div enter”> 姓 名 </div></td> 
<td width="143" bgcolor="#ED9438"><div align="center"> 班 级 </div></td> 
<td width="130" bgcolor="#ED9438"><div align="center"> 科 目 
</div></td> 

<td width="131" bgcolor="#ED9438"><div align="center"> 成 绩 </div></td> 

</ltr> 

<?php 

while(!$rs->eof){ 

?> 


<tr> 
<td width="170" height="20" ><div align="center"><?php $f=$rs->fields("sno"): echo iconv('gbk','utf-8',$f->value):?></div></td> 
<td width="170" bgcolor="#FFFFFF"><div align="center"><?php echo iconv('gbk','utf-8',.$rs->ficlds("sname")->value):?></div></td> 
<td width="143" bgcolor="#FFFFFF"><div align="center"><?php echo iconv('gbk','utf-8'.$rs->ficlds("sclass")->value):?></div></td> 
<td width="130" bgcolor="#FFFFFF"><div align="center"><?php echo iconv('gbk','utf-8',$rs->ficlds("ssubject")->value):?></div></td> 
<td width="131" bgcolor="#FFFFFF"><div align="center"> 
<?php 
Sf=$rs->ficlds("sscore"); 
echo $f->value; 
if($f->value<60){ 
$sum++; 
} 
></div></td> 
</tr> 
<?php 
S$rs->movenext; 
} 
} 


?> 


国 秘笈 心 法 
心 法 领悟 508: 操作 Access 数据 库 对 记录 集 游标 的 使 用 。 
以 $rs->open($sql,$conn,A,B) 为 例 , 参数 A、B 取 不 同 的 值 使 游标 具有 不 同 的 属性 , 如 表 11.1 和 表 11.2 所 示 。 


表 11.1 参数 A 的 用 法 


A 的 取 值 用 法 
0 只 读 ， 当 前 记录 集 指针 只 能 下 移 
1 只 读 ， 当 前 记录 集 指针 可 自由 移动 
2 可 读 写 ， 当 前 记录 集 指针 可 自由 移动 
3 可 读 写 ， 当 前 记录 集 指针 可 自由 移动 并 可 看 到 新 增 记录 
表 11.2 参数 B 的 用 法 
B 的 取 值 用 法 
1 | 默认 锁定 类 型 ， 记 录 集 只 读 ， 不 能 修改 记录 


翡 观 锁定 ， 当 修改 记录 时 ， 数 据 提供 者 将 尝试 锁定 记录 以 确保 成 功 编辑 记录 ， 只 要 编辑 一 开始 则 
立即 锁定 记录 


乐观 锁定 ， 直 到 用 update0 方 法 提交 更 新 的 记录 时 才 锁 定 记录 
批量 乐观 锁定 ， 人 允许 修改 多 个 记录 ， 只 有 调用 update batch0 方 法 时 才 锁 定 记 录 
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实例 509 


力 实例 说 明 


高 级 
趣味 指教， 机 本 页 页 ， 


如 果 记 录 集 中 的 记录 较 多 ， 用 一 个 页 面 显示 所 有 记录 会 给 用 户 的 浏览 带 来 诸多 不 便 。 为 了 解决 这 个 问题 ， 
可 以 对 数据 库 中 的 数据 进行 分 页 显示 。 运 行 本 实例 ， 如 图 11.5 所 示 。 


pn 开关 不 与。 人民 pt 入 


Delpn 逆 据 孟 开发 实 全 多 夺 a 
ASP 小 括 库 开 友 实 了 入 术 可 误工 b 居 社 
visual FoxPro 机 本 开发 信人 解 下 。 起 工业 出 睛 社 
Powar Bulder 信 基于 开发 实 列 解 泊 ”也 误工 业 比 斋 社 
visual Basicg 到 认 开 实 创 解 氏 大 起 工业 出 版 社 
| visual Baslc 本 条 畏 程 200 创 机 城 工业 流入 
刁 有 图书 47 隐 竹下 旦 示 20 种 第 3 页 失 3 责 
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ET Tr 
2004 年 5 月 407 页 4 元 | 
2004 年 2 月 480 页 哲 元 | 
2004 年 12 月 321 页 36 元 | 
2003 征 9 月 458 页 各 无 | 
2003 征 9 月 400 页 43 元 | 
2003 年 6 月 460 页 向 元 | 
2003 年 1 月 358 页 39 元 | 
waiaa 站 加 


图 11.5 数据 的 分 页 显示 


图 关键 技术 


PHP 利用 COM 类 连接 数据 库 ， 可 以 直接 使 用 类 中 的 数据 成 员 完 成 很 多 操作 ， 常 用 的 数据 成 员 如 表 11.3 


所 示 。 
表 11.3 ”记录 集 对 象 常用 数据 成 员 

数据 成 员 说 明 
pagesize 设置 分 页 显示 时 ， 记 录 集 对 象 一 页 所 容纳 的 记录 数 
absolutepage 设置 当前 显示 的 为 第 几 页 ， 首 先 应 设置 pagesize 的 值 
bof 检查 当前 记录 集 对 象 所 指 位 置 是 否 为 第 一 条 记录 之 前 
eof 检查 当前 记录 集 对 象 所 指 位 置 是否 为 最 后 一 条 记录 之 后 
pagecount 显示 记录 集 当前 页 面 总 数 ， 首 先 应 设置 pageesize 的 值 
movenext 将 记录 集 对 象 的 指针 向 下 移动 一 条 


力 设计 过 程 


(1) 建立 数据 库 连接 文件 conn.php， 代 码 如 下 : 
<?php 
Sconn = new com("adodb.connection"); 
Sconnstr="driver={microsoft access driver (*.mdb)}: dbq=". 
realpath("../data/db_databasel1.mdb "); 
Sconn->open($connstr); 
> 


2) 根据 接收 到 的 查询 字符 串 的 值 确定 显示 的 信息 页 ， 代 码 如 下 : 
<php 


include("Conn/conn.php"): 

$sql="select * from tb_bookinfo order by pdate dese"; 
Srs=new com("adodb.recordset"): 
Srs->open($sql.Sconn.1.3): 

Srs->pagesize=20; 


// 包 含 数据 库 连 接 文件 conn.php 

// 查 询 也 _bookinfo 表 中 的 所 有 商品 
// 用 com 类 声明 一 个 记录 集 对 象 

// 利 用 com 类 的 open0 方 法 执行 查询 
// 设 置 每 页 最 多 显示 20 条 记录 
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(trim(intval($_GET[page]))—"")|(intval($_GET[page])>S$rs->pagecount)|(intval($_GET[page])<=0)) { 


Spage=1: 
} else{ // 否 则 使 $page 的 值 为 所 接收 的 查询 字符 串 的 数值 
Spage=intval($_GET[page]): 
和 
if($rs->eof | $rs->bof) { // 潮 断 表 中 的 内 容 是 否 为 室 ， 如 果 为 空 则 给 出 提示 
> 
<tr> 
<td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 本 站 暂 无 商品 ! 
<Jdiv></td> 
<ltr> 
<?php 
jelse{ /不 为 空 则 分 页 显示 数据 
S$rs->absolutepage=$page; /设置 当前 显示 页 为 所 接收 的 查询 字符 串 的 值 
Smypagesize=$rs->pagesize; /定义 变量 $mypagesize 用 于 控制 当前 页 的 循环 终止 
while(!$rs->eof && $mypagesize>0) { // 记 录 集 对 象 没有 到 整个 表 尾 并 且 当 前 页 所 要 显示 的 记录 没有 完全 显示 完 ， 则 循环 显示 数据 信息 
?> 
<?php 
Smypagesize--; // 每 显示 一 条 记录 ， 应 使 $mypagesize 的 值 减 1 
S$rs->movenext; /使 记录 集 指针 移 到 下 一 条 记录 的 位 置 
} 
} 
> 


(3) 向 信息 显示 页 面 发 送 查 询 字符 串 从 而 实现 商品 信息 的 分 页 显示 ， 代 码 如 下 : 
<div align="right"> 
<?php 
if($page>=2){ 
> 
<a href="index.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> 
<a href="index.php?page=<?php echo Spage-1:?>" title=" 前 一 页 "><font face="webdings"> 7 </font></a> 
Iphp 
} 
if($rs->pagecount<—=4){ 
for($i=1:$i<=$rs->pagecount: $i++){ 
> 
<a href="index.php?page=<?php echo $i;?>"><?php echo $i:7></a> 
Iphp 


站 
jelse{ 
forGSi=1:Si<=4:SitHf 


<a href="index.php?page=<?php echo $i:?>"><?php ccho Si:?></a> 


<a href="index.php?page=<?php 
这 $rs->pagecount>=$page+l) 
echo Spagetl1; 


一 页 "><font face="webdings"> 8 </font></a> 
<a href="index.php?page=<?php echo $rs->pagecount;?>" title=" 尾 页 "><font face="webdings"> : </font></a> 
<?php 

} 


?> 
</div> 
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心 法 领悟 509: 比较 ASP 与 PHP。 
熟悉 ASP 的 读者 可 能 会 发 现 , PHP 利用 COM 类 连接 Access 数据 库 的 思路 与 ASP 用 ADO 方法 连接 数据 库 
的 思路 类 似 ， 同 样 实现 翻 页 的 思路 也 是 类 似 的 。 
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趣味 指教 : 请 禄 庚 寅 ， 


i 


力 实例 说 明 


利用 用 户 身 份 验证 类 实现 登录 用 户 的 身份 验证 ， 不 仅 为 以 后 的 维护 工作 带 来 很 大 方便 ， 而 且 还 可 以 提高 程 
序 的 安全 性 。 运 行 本 实例 ， 如 图 11.6 所 示 ， 如 果 登 录用 户 输入 正确 的 用 户 名 和 密码 则 系统 给 出 成 功 登 录 信息 ， 
反之 系统 给 出 登录 失败 信息 。 


NT 
ez ~ 


于 下 


EE 


11.6 ”登录 Access 数据 库 成 功 


力 关键 技术 
本 实例 主要 通过 面向 对 象 的 类 来 实现 用 户 身份 的 验证 ， 用 户 身份 验证 类 的 代码 如 下 


class chk{ 
Private $name; 
private Spwd:; 
public function «construct($x,$y){ 
Sthis->name=$x; 


Srs=new com("adodb.recordset"); /创建 记录 集 对 象 
Srs->open("select * from tb_user where usemame=".$this->name." and userpwd=".$this->pwd.™",$conn,3.1); 
if($rs->eof | $rs->bof){ 
od "<script>alert(' 对 不 起 ， 密 码 或 用 户 名 错误 !):history.backO:</script>": 


a 
echo "<script>alert( 恭喜 您 登录 成 功 !):history.back0O:</script>": 
exit; 


} 
. 


} 
该 类 通过 判断 数据 库 中 查询 结果 的 游标 位 置 来 判断 用 户 输入 的 用 户 名 和 密码 是 否 正确 ， 如 果 该 游标 位 于 第 
一 条 记录 之 前 或 最 后 一 条 记录 之 后 ， 则 说 明 用 户 输入 的 用 户 名 或 密码 错误 。 


力 设计 过 程 
(1) 建立 如 图 11.6 所 示 的 登录 表单 ， 代 码 如 下 


<form name="form1" method="post" action="index.php"> 
<t> 
<td height="25" colspan="2" bgcolor="#0099CC"><div align="center" class="STYLE1"> 用 户 身份 验证 </div></td> 
<t> 
<t> 
<td width="60" height="25" bgcolor="#FFFFFF"><div align="center"> 用 户 名 : </div></td> 
<td width="187" bgcolor="#FFFFFF"><div align="left">é&nbsp:<input type="text" name="usemame" size="22" 
class="inputess"></div></td> 
<ltr> 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"> 密 码 : </div></td> 
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<td height="25" bgcolor="#FFFFFF"><div align="left">&nbsp:<input type="password" name="userpwd" size="22" 
class="inputess"></div></td> 
<itr> 
<t> 

‘<td height="25" colspan="2" bgcolor="#FFFFFF"><div align="center"><input name="submit" type="submit" value=" 登 录 " 
class="buttoncss"></div></td> 

</it> 
</form> 


(2) 建立 密码 验证 类 。 
(3) 美的 实例 化 并 实现 用 所 身份 的 蛤 证 代码 如 下 : 


Schkl=new chk($usemame. $userpwd): 
Schk1->chkuser(); 


心 法 领悟 10， 类 的 实例 化。 


一 般 情 况 下 ， 创 建 一 个 类 后 并 不 能 直接 对 类 中 的 属性 和 方法 进行 引用 ， 必 须 对 类 进行 实例 化 ， 即 创建 一 个 
对 象 。PHP 中 用 new 关键 字 创 建 对 象 。 


实例 511 时 
图 实例 说 明 
采用 分 栏 的 方式 将 多 张 图 片 同时 显示 在 一 个 页 面 中 , 可 以 
使 页 面 更 加 整齐 。 运 行 本 实例 ， 效 果 如 图 11.7 所 示 。 
图 关键 技术 
本 实例 实现 图 片 的 分 栏 显示 主要 依靠 标记 变量 Si， 如 果 该 
变量 的 值 能 被 5 整除 则 显示 下 一 行 ( 当 然 这 是 一 栏 显 示 5 张 图 


片 的 情况 ， 如 果 一 栏 显示 4 张 图 片 ， 可 以 通过 判断 该 值 能 否 被 4 整除 ， 依 此 类 推 ) 。 注 意 ， 显 示 一 张 图 片 后 应 
使 $i 的 数值 加 1， 实 现 该 过 程 的 代码 如 下 : 
<?phbp 
Si=1; 


while(lSrs->eob{f 
让 (Si% 5 一 0){ 


11.7 图 片 的 分 栏 显示 


> 
<td height="25"> 
<div align="left"><img sre="<?php echo iconv('gbk','utf-8'.$rs->fields(address)->value):?>" border="0">&nbsp:</div> 
<ltd> 
<ltr> 
<?php 
jelsef 


<td height="25"><div align="left"><img sre="<?php echo iconv(gbkvutf 8,Srs->fieldstaddress) >valucj:?>v border="0">&enbsp;</div> 
<htd> 


| | 设计 过 过 程 
(1) 建立 与 Access 数据 库 的 连接 ， 代 码 如 下 : 
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<?php 
Sconn=new com("adodb.connection"); 
Sconnstr="provider=microsoftjet.oledb.4.0;data 
source=".realpath("../data/db_databasel1.mdb "); 
S$conn->open($connstr); 
> 


(2) 广 测 数据库 中 二 多 未 区 并 的 光斑 并 获 得 记 水 信 、 代码 如 下 : 

Srs->open($sql,Sconn,1,3): 

(3) 实现 图 片 的 分 栏 显示 ， 该 部 分 代码 已 经 在 关键 技术 中 给 出 ， 这 里 不 再 袭 述 。 
力 秘笈 心 法 


心 法 领悟 511: 浅 谈 分 栏 显示 。 
所 谓 的 分 栏 显示 ， 就 是 取得 标记 变量 的 值 进行 一 些 规定 方法 的 运算 ， 当 运算 结果 符合 条 件 时 ， 便 对 标记 变 
量 的 对 应 内 容 进行 分 栏 。 其 实 分 栏 操作 只 是 编程 世界 中 的 一 个 小 技巧 ， 是 程序 员 经 验 不 断 积 累 的 结果 。 


力 实例 说 明 


为 了 让 读者 从 多 个 方向 了 解 和 学 习 Access 数据 库 ， 本 实例 将 利用 ADODB 技术 对 Access 数据 库 进行 操作 ， 
使 读者 在 操作 Access 数据 库 方面 又 多 掌握 一 种 方法 。 运 行 本 实例 ， 效 果 如 图 11.8 所 示 。 


图 11.8 插入 图 书信 息 


力 关键 技术 


本 实例 的 关键 点 是 灵活 运用 ADODB 的 相关 函数 ， 包 括 以 下 几 个 。 

ADONewConnection0: 连接 数据 库 系 统 。 

PConnect($host,[$user], [Spassword], [Sdatabase]): 持久 化 连接 数据 库 。 

Execute($sql[,$inputarr=false]): 执行 SQL 语句 并 返回 一 个 结果 集 (ADORecordSet 对 象 ) ， 如 果 失 败 则 返回 
FALSE。 


本 实例 利用 ADODB 实现 连接 Access 数据 库 的 代码 如 下 : 

require_once("../adodb5/adodb.inc.php"): /引入 文件 

$conn = ADONewConnection('access): /连接 Access 数据 库 

S$conn -> Connect("Driver={Microsoft Access Driver (* mdb)}: Dbq= F:\AppServ\iwww\IMR\\1 1\\data\\db_databasel1.mdb "): 


有 关 ADODB 技术 的 详细 讲解 ， 读 者 可 以 参考 本 书 第 13 章 的 内 容 。 
图 设计 过 程 
(1) 通过 ADODB 连接 数据 库 ， 代 码 见 关键 技术 。 
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(2) 编写 “显示 信息 ”按钮 ， 单 击 此 按钮 ， 将 输出 Access 数据 库 中 存储 的 所 有 数据 ， 代 码 如 下 : 


<?php 

if$_GET[d] —"1"){ // 单 击 按钮 
S$rst = $conn -> execute("select * from th_demo") or die ("出 错 "); // 返 回 结果 集 

> 


<table bgcolor="#80E7EC" width="580px"><tr><td align="center"> 图 书 ID</td><td align="center"> 图 书 名称 </td><td align="center"> 作 者 </td><td 
align="center"> 出 版 社 </td><td align="center"> 出 版 时 间 </td></tr> 


hp 
while(!$rst -> EOF){ // 如 果 指针 没有 指向 最 后 一 条 数据 


<t> 
<td align="center" bgcolor="AFFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> ficlds[0]):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> ficlds[1]):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312", "utf-8",$rst -> ficlds[2]):?></td> 


<td align="center" bgeolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> fields[3]):?></td> 
<td align="center" bgeolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> fields[4]);?></td> 
</t> 
php 
S$rst -> movenext(); /指针 向 下 移动 
国 } 
(3) 编写 表单 ， 通 过 字符 串 拆 分 函数 ， 对 文本 框 内 容 进 行 拆 分 并 执行 插入 操作 ， 代 码 如 下 : 
<?php 
i PosTfmbDf /| 单 击 按钮 
这 $_POST[te] 一 "||$_POST[te] 一 "输入 字段 信息 每 一 项 用 空格 分 割 "){ 1/ 判断 文本 框 内 容 
echo "<script>alert(' 请 在 文本 框 中 输入 内 容 );location href='index.php?id=1';</script>"; //JavaSeript 提示 
Jelse{ 
S$array = explode(" ",$_POST[te]): /| 拆 分 字符 串 
if(count($array) != 5){ 1/ 判断 数组 
echo "<script>alert( 文 本 框 输入 内 容 有 误 ,数据 表 共 5 个 字段 ");location.href='index.php?id=1';</script>";  ///JavaScript 提示 
Jelse{ 
/| 转 码 操作 
,gbk', 了 
Se= =iconv(utf.g" ,gbk'Sarray[4]); 
// 判 断 是 否 插入 成 功 
if($conn -> exeeute("insert into tb_demo( id, ‘bname, author’, pub, date’)values(™.$a.™,".$b.™,".$e.™,".$d.™,".Se.")"){ 
echo "<script>alert( 插 入 数据 成 功 );location.href="'index.php?id=1";</script>"; //JavaScript 提示 
Jelse{ 
echo "<script>alert('SQL 语句 有 误 ， 请 重新 输入 ):location_ href='index.php?id=1';</script>"; 
} 
} 
| 
} 
?> 


国 秘笈 心 法 


心 法 领悟 512: Access 数据 库 的 SQL 语句 。 
Access 数据 库 与 MySQL 数据 库 的 SQL 语句 在 更 新 、 删 除 、 查 询 方面 几乎 相同 ， 但 是 在 插入 语句 方面 有 所 
不 同 。 在 编辑 插入 的 insert 语句 时 ， 数 据 表 字段 必须 由 “` ”包含 。 


实例 513 


国 实例 说 明 


Access 数据 库 虽 然 小 巧 ， 但 是 在 功能 上 并 不 逊 于 其 他 数据 库 ， 进 行 简单 的 插入 、 删 除 操作 是 很 迅速 的 。 本 
实例 通过 ADODB 连接 Access 数据 库 实现 删除 图 书信 息 的 操作 ， 运 行 结果 如 图 11.9 所 示 。 
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3 | PHP 实 法皇 实 
1 | FP 由 六 和 
工人 王 到 


图 11.9 删除 图 书信 息 


图 关键 技术 


本 实例 的 关键 点 是 利用 ADODB 实现 连接 Access 数据 库 ， 代 码 如 下 : 
require_once("../adodb5/adodb.inc.php"); 1/ 引 入 文件 

$conn = ADONewConnection('access'): /连接 Access 数据 库 
$conn -> Connect("Driver={Mierosoft Access Driver (*.mdb)}; Dbq= F:\AppServ\www\MR\\11\\data\db_database11.mdb "); 


图 设计 过 程 
(1) 通过 ADODB 连接 数据 库 ， 代 码 见 关键 技术 。 
(2) 编写 “显示 信息 ”按钮 ， 单 击 该 按钮 ， 将 输出 Access 数据 库 中 的 所 有 数据 ， 代 码 如 下 : 


<2php 
if($_GET[id] 一 "19{ // 单 击 按钮 

Srst = $conn -> execute("select + from tb_demo") or die ("出 错 "); 1/ 返回 结果 集 
?> 
<table bgeolor="#80E7EC" width="580px"> 

hp 

while(!$rst -> EOF){ /如 果 指针 没有 指向 最 后 一 条 数据 
> 

<tr> 


<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> ficlds[01):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> ficlds[1]):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> ficlds[2]):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> ficlds[3]):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst -> ficlds[4]):?></td> 


Srst -> movenext0; // 指 针 向 下 移动 
?> 


(3) 根据 form 表单 中 提交 的 ID 值 ， 执 行 delete 语句 删除 指定 的 数据 ， 代 码 如 下 : 


<?php 
if($_POST[sub){ // 单 击 按钮 
这 $_POST[te] 一 "||$_POST[te] 一 "输入 图 书 ID"){ // 判 断 文本 框 内 容 
echo "<script>alert(' 请 在 文本 框 中 输入 内 容 ):location href=index.php?id=1';</script>"; //JavaScript 提示 
yelse{ 
if(!preg_match("/N\d/",$_POST[te]){ // 验 证 文本 框 内 容 
echo "<script>alert( 文 本 框 内 容 不 是 数字 ， 或 超出 范围 );</script>"; /avascript 提示 
jelsef 
$sql = "delete from tb_demo where id=$_POST[te]"; //SQL 语句 
这 $conn -> execute($sqD){ 1/ 执行 删除 操作 


echo "<script>alert(' 执 行 删除 操作 成 功 ):location.href='index.php?id=1':</script>"://JavaScript 提示 
Jelse{ 
echo "<script>alert('SQL 语句 有 误 '):location href='index.php?id=1';</script>"; 


心 法 领悟 513: 什么 是 ADODB。 
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ADODB, 全 称 为 Active Data Objects Data Base， 是 存 取 数 据 库 所 使 用 到 的 一 组 函数 。 虽 然 PHP 是 构建 Web 
系统 强 有 力 的 工具 ， 但 是 由 于 PHP 存 取 函 数 一 直 没有 标准 化 ， 不 同 数据 库 间 的 函数 名 称 、 参 数 差 异 很 大 ， 在 更 
换 数据 库 时 会 带 来 大 量 的 代码 修复 工作 。 这 时 就 需要 一 组 函数 库 来 隐藏 不 同 数据 库 函 数 间 的 差异 ， 以 便 开 发 者 
可 以 简单 地 切换 数据 库 ， 这 就 是 ADODB 类 库 ， 其 详细 的 讲解 请 读者 参考 本 书 第 13 章 。 


11.3 ”Access 数据 库 的 安全 


数据 库 文件 的 安全 非常 重要 ， 尤 其 是 对 于 利用 Access 数据 库 建立 的 小 型 网 站 而 言 ， 用 户 总 是 担心 数据 库 文 
件 会 不 会 被 下 载 、 用 户 名 和 密码 是 否 会 被 他 人 盗 走 、 系 统 是 否 会 被 人 攻击 等 。 下 面 通过 具体 实例 来 讲解 网 站 的 
安全 措施 。 


i 


实例 514 趣味 指数 ， 庚 良 志雄 ， 


力 实例 说 明 


为 防止 用 户 通过 下 载 Access 数据 库 文件 来 达到 窃取 机 密 信 息 的 目的 , 可 以 为 Access 数据 库 设置 密码 , 以 保 
护 数据 ， 这 样 即使 用 户 得 到 数据 库 也 会 因为 没有 密码 而 无 法 查看 数据 库 中 的 内 容 。 运 行 本 实例 ， 对 Access 数据 
库 设置 密码 的 效果 如 图 11.10 所 示 ， 在 网 站 中 连接 数据 库 的 运行 结果 如 图 11.11 所 示 。 
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图 11.10 设置 数据 库 密码 11.11 操作 带 密码 的 Access 数据 库 


力 关键 技术 


本 实例 主要 通过 Access 菜单 栏 中 的 “工具 ”/“ 安 全 ”/“ 设 置 数据 库 密码 ”命令 来 设置 Access 数据 库 的 密 
码 ， 同 时 也 可 以 撤销 数据 库 密码 。 

撤销 数据 库 密码 的 过 程 为 选择 Access 菜单 栏 中 的 “工具 ”/“ 安 全 ”/“ 撤 销 数据 库 密码 ”命令 ， 在 弹出 的 
“撤销 数据 库 密码 ”对 话 框 中 输入 设置 时 的 密码 即 可 。 


安 提示 : 在 设置 或 者 撤销 Access 数据 库 的 密码 时 ， 必 须 将 数据 库 以 独占 的 方式 打开 。 
设计 过 程 
(1) 启动 Access 数据 库 ， 单 击 工具 栏 中 的 加 按钮 ， 弹 出“ 打开” 对话 框 ， 选 择 需 要 设置 密码 的 数据 库 文 


件 ， 例 如 bookinfo.-mdb， 单 击 “ 打 开 ” 按 钮 右 侧 的 下 三 角 按钮 加 ， 在 弹出 的 下 拉 列 表 中 选择 “以 独占 方式 打开 ” 
选项 ， 则 该 数据 库 文件 将 以 独占 方式 打开 。 
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(2) 选择 主 菜单 上 的 “工具 ”/“ 安 全 ”/“ 设 置 数据 库 密码 ”命令 ， 将 弹出 如 图 11.10 所 示 的 对 话 框 ， 在 
该 对 话 框 中 输入 密码 及 密码 验证 码 ， 单 击 “ 确 定 ”按钮 即 可 完成 密码 的 设置 。 

(3) 采用 ADO 方式 连接 加 密 的 Access 数据 库 。 注 意 ， 连 接 加 密 的 Access 数据 库 时 ， 只 需 在 数据 库 连接 
驱动 中 通过 关键 字 pwd 指定 密码 字符 串 即 可 ， 代 码 如 下 : 


<?php 
// 利 用 PHP 预定 义 类 com 声明 一 个 数据 库 连接 对 象 ， 并 利用 ADO 连接 数据 库 
Sconn = new com("adodb.connection"): 


/设置 数据 库 连接 驱动 
S$connstr="driver={microsoft access driver (*.mdb)}:pwd=mrsoft; dbq=". realpath("data/db_bookinfo.mdb"); 
$conn->open($connstr); // 调 用 COM 类 的 open0 方 法 来 执行 上 述 连 接 驱 动 
> 
(4) 完成 图 书信 息 分 页 显示 ， 其 关键 代码 如 下 : 
php 
include("conn/conn.php"); // 包 含 数据 库 连接 文件 conn.php 
$sql="select * from tb_bookinfo order by pdate dese"; 。“”// 查 询 也 _bookinfo 表 中 的 所 有 图 书信 息 
Srs=new com("adodb.recordset"); /用 COM 类 声明 一 个 记录 集 对 象 
Srs->open(SsqlSconn,1.3): // 利 用 COM 类 的 open0 方 法 执行 查询 
Srs->pagesize=10; // 设 置 每 页 最 多 显示 10 条 记录 
ne GET[pageD))=—="")ll(intval($ GET[pagel)>$rs->pagecount)ll(intval($ GET[page])<=0)){ 
page=1; 
Jelse{ // 否 则 使 page 的 值 为 所 接收 的 查询 字符 串 的 数值 
i Spage=intval($ GET[page]): 
if($rs->eof | $rs->bof) { // 判 断 表 中 的 内 容 是 否 为 空 ， 如 果 为 空 则 给 出 提示 
?> 
<tr><td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 本 站 暂 无 图 书信 息 ! </div></td></tr> 
<?php 
jslse{ // 不 为 空 则 分 页 显示 数据 
Srs->absolutepage=$page; 1/ 设置 当前 显示 页 为 所 接收 的 查询 字符 串 的 值 
Smypagesize=$rs->pagesize:; // 定 义 变量 Smypagesize 用 于 控制 当前 页 的 循环 终止 


while(!$rs->eof && Smypagesize>0) { // 记 录 集 对 象 没有 到 整个 表 尾 并 且 当 前 页 所 要 显示 的 记录 没有 完全 显示 完 ， 则 循环 显示 数据 信息 


align="center"><?php $ficlds=$rs->ficlds(tpi):ccho $ficlds->value:?></div></td> 
"AFFFFFF"><div align="center"><?php $ficlds=$rs->ficlds(pdate);echo $fields->value:?></div></td> 
‘center" bgcolor="#FFFFFF"><?php $ficlds=$rs->ficlds(bookpage):echo $ficlds->value:?>&nbsp: 页 </td> 
<td height="20" align="center" bgcolor="#FFFFFF"><?php $ficlds=$rs->ficlds(price):;echo $fields->value:?>&nbsp; 元 </td> 


</t> 
<?php 
$mypagesize--: /每 显示 一 条 记录 ， 应 使 Smypagesize 的 值 减 1 
S$rs->movenext; /使 记录 集 指针 移 到 下 一 条 记录 的 位 置 
} 
} 
> 


< 
<t> 

<td width="283" height="25"><div align="left"> 本 站 共有 图 书 <?php echo $rs->recordcount:?> 种 &nbsp: 每 页 显示 <?php echo Srs->pagesize:?> 种 
&nbsp: 第 <?php echo $page;?> 页 / 共 <?php echo Srs->pagecount:?> 页 <ldiv></td> 

<td width="263"><div align="right"> 
<?php 

这 Spage>=2) { // 如 果 当 前 显示 页 的 页 码 大 于 2， 则 显示 首页 和 返回 前 一 页 链接 

?> 


<a href="index.php?page=1" title=" 首 页 "><font face="webdings"> 9 </font></a> 
<a href="index.php?page=<?php echo $page-1:?>" title=" 前 一 页 "><font face="webdings"> 7 </font></a> 


和 
if($rs->pagecount<=4) { // 如 果 总 页 数 小 于 等 于 4， 则 显示 到 所 有 页 的 链接 
for($i=1:$i<=$rs->pagecount:$i++){ 
> 
<a href="index.php?page—<?php echo Si:?>"><?php echo $i:7></a> 
<?php 
jslse{ // 如 果 总 页 数 大 于 4， 则 显示 到 前 4 页 的 链接 
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for($i=1;$1<=4:$i++) { 
<a href="index.php?page=<?php echo $i:?>"><?php echo $i:7></a> 


> 


<2php 
} 


<a href="index.php?page=<?php 
if($rs->pagecount>=S$page+1) // 如 果 到 下 页 链接 的 页 码 大 于 总 页 数 则 显示 第 一 页 
echo $pagetl; 
else 
echo 1; 
?>" title=" 后 一 页 "><font face="webdings"> 8 </font></a> 
<a href="index.php?page=<?php echo $rs->pagecount:?>" title=" 尾 页 "><font face="webdings"> : </font></a> 
?php 


> 


<form name="form1" method="get" action="index.php"> 
<input type="text" name="page" size="2" class="inputcss"> 
<input name="submit" type="submit" class="buttoncss" value="GO"> 
</form> 


国 秘笈 心 法 

心 法 领悟 514: 支持 跳 转 的 分 页 显示 功能 。 

在 本 实例 中 应 用 面向 过 程 的 技术 编写 分 页 方法 ， 实 现在 不 同 页 面 之 间 的 跳 转 、 上 一 页 和 下 一 页 之 间 的 跳 转 
以 及 跳 转 到 指定 页 面 的 功能 。 


力 实例 说 明 

在 开发 中 小 型 Web 应 用 程序 时 ， 通 常 采用 Access 数据 库 ， 因 为 应 用 Access 数据 库 比 较 方便 。 在 站 点 上 传 
时 ， 通 常 将 数据 库 文件 和 其 他 文件 一 同上 传 到 网 站 服务 器 中 ， 但 是 这 样 做 是 极 不 安全 的 ， 一 旦 被 用 户 猜测 到 数 
据 库 的 相对 路 径 ， 用 户 在 客户 端 便 可 以 下 载 该 数据 库 文件 。 例 如 ， 用 户 猜测 到 某 网 站 的 数据 库 保 存在 站 点 目录 
的 db_news.mdb 文件 中 ， 在 浏览 器 的 地 址 栏 中 输入 http://127.0.0.1/mr/11/010/data/db_news.php 后 ， 即 可 弹出 如 
图 11.12 所 示 的 文件 下 载 对 话 框 。 


力 关键 技术 


解决 以 上 问题 的 方法 是 将 数据 库 文件 的 扩展 名 由 .mdb 改 为 .php， 即 在 连接 数据 库 时 ， 将 数据 库 文件 指定 
为 .php 文件 即 可 。 此 时 再 打开 该 文件 《db_newsphp) 时， 将 会 出 现 如 图 11.13 所 示 的 效果 。 在 默认 情况 下 ， 文 
件 夹 内 存放 的 文件 的 扩展 名 是 不 显示 的 ， 此 时 无 法 修改 文件 的 扩展 名 。 


您 下 要 打开 区 从 还 是 格局 人 让 到 BOE+ 扣 了 


sw | [ERes | wesaw 


Wy EJP 


图 11.12 在 客户 端 下 载 数据 库 文件 图 11.13 在 记事 本 中 打开 的 数据 库 文件 
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图 设计 过 程 
(1) 修改 实例 中 所 用 数据 库 的 扩展 名 ， 将 其 命名 为 db_news.php。 


(2) 新 建 conmn 文件 夹 ， 编 辑 conn.php 文件 ， 定 义 Access 数据 库 的 连接 方法 ， 其 代码 如 下 : 
Se =new com("adodb.connection"); 
Sconnstr—"driver={microsoft access driver (*.mdb)}: dbq=". realpath("data/db_news.php"); 


Sconn->open($connstr); 
?> 
(3) 新 建 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 应 用 while 语句 完成 数据 库 中 数据 的 循环 输出 ， 其 关键 
代码 如 下 : 

<php 
include("conn/conn.php"); // 包 含 数据 库 连 接 文件 
$sql="select * from tb_news order by pdate desc"; // 定 义 查询 语句 
Srs=new com("adodb .recordset"); // 实 例 化 类 
Srs->open($sql,$conn,1,3); // 执 行 查询 操作 
if($rs->eof | Srs->bop{ // 判 断 查询 结果 是 否 为 真 


?> 
<tr><td height="20" colspan="5" bgcolor="#FFFFFF"><div align="center"> 暂 无 新 闻 信 息 ! </div></td></tr> 


Jelse{ 
while(!$rs->eof){ /循环 输出 查询 结果 
?> 
<u> 
<td height="20" align="center" bgcolor="#FFFFFF"><div align="center"> 
<?php $ficlds=$rs->ficlds(type):echo $fields->value:?> 
</div></td> 
<td height="20" align="left" bgcolor="#FFFFFF"><div align="left"> 
<?php $ficlds=$rs->ficlds(newobj);echo $fields->value:?> 
</div></td> 
<lt> 
<php 
S$rs->movenext: 


} 


?> 


图 秘笈 心 法 
心 法 领悟 515; Access 数据 库 的 安全 。 


首先 为 Access 数据 库 设置 密码 ， 然 后 更 改 Access 数据 库 文件 的 后 级 名 称 ， 通 过 这 两 项 设置 ， 相 信 Access 
数据 库 的 安全 可 以 得 到 一 定 的 保障 。 


11.4 Access 数据 库 的 综合 运用 


本 节 以 Access 数据 库 为 数据 的 存储 方式 , 开发 一 个 聊天 室 功能 模块 , 通过 这 个 功能 模块 体会 Access 数据 库 
在 完整 项 目 中 的 运用 。 


A 高 级 | 
实例 516 趣味 指数 ， 宽 本 女 页 
图 实例 说 明 


在 本 实例 中 介绍 通过 ADODB 类 库 连 接 Access 数据 库 ， 这 里 连接 的 Access 数据 库 是 具有 密码 的 ， 并 且 隐 
藏 了 Access 数据库 文件 的 后 绥 。 运 行 本 模块 中 的 top.php 文件 ， 就 可 以 测试 出 数据 库 是 否 连接 成 功 ， 如 果 连 接 
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成 功 ， 将 输出 如 图 11.14 所 示 的 页 面 。 


[3 是 an5 征 月 日 星期 = 


11.14 ”成功 连接 Access 数据 库 


图 关键 技术 


这 里 应 用 ADODB 类 库 连接 Access 数据 库 ， 并 且 Access 数据 库 设置 了 密码 ， 同 时 对 数据 库 文件 名 称 的 后 
组 进行 了 修改 。 所 以 在 封装 Access 数据 库 的 连接 类 时 ， 必 须 注意 以 下 内 容 : 


要 指定 正确 的 ADODB 类 库 的 调用 路 径 。 


Access 数据 库 的 访问 密码 为 mrsoft。 
Access 数据 库 文 件 的 后 缀 是 .php。 


图 设计 过 程 


办 办 办 罗 


由 于 使 用 ADODB 类 库 操作 Access 数据 库 ， 数 据 库 类 型 的 判断 应 该 使 用 ado_access。 
定义 连接 语句 时 ， 不 要 忘记 Driver 与 (*.mdb) 之 间 的 空格 。 


(1) 定位 ADODB 类 库 的 位 置 ， 将 其 存储 于 章 目录 11 下 ， 命 名 为 adodb5。 
(2) 定位 Access 数据 库 文件 的 位 置 ， 将 其 存储 于 11\011\data 文件 夹 下 ， 命 名 为 db_messages.php。 
(3) 在 11\011\conn 文件 夹 下 新 建 ConnDB.php 文件 ， 封 装 ADODB 连接 Access 数据 库 类 ， 其 代码 如 下 : 


<?php 

class ConnDB{ 
var $dbType; 
var $host: 
Var $userName; 
Var $pwd; 
var $dbName; 
var $isDebug; 
var $connID; 


/| 数据 库 类 型 标识 

/| 数据 库 服务 器 地 址 
/| 数据 库 服务 器 用 户 名 
// 数 据 库 用 户 密码 

// 要 连接 的 数据 库 名 
/是 否 显示 调试 信息 
/| 数据 库 连 接 ID 


function ConnDB ($dbType = ‘mysql', $host, $userName, $pwd. $dbName, SisDebug = false){ 


Sthis->dbType = $dbType: 
S$this->host = $host 
S$this->userName = $userName; 
Sthis->pwd = Spwd: 
S$this->dbName = $dbName: 
Sthis->isDebug = $isDebug: 


} 
function getConnID Of 
require_once ,adodbsladodb inc.php': 
S$this->connID = NewADOConnection($this->dbType): 


// 为 数据 库 类 型 赋 初 值 
// 为 服务 器 地 址 赋 初 值 
// 为 用 户 名 赋 初 值 

// 为 密码 赋 初 值 

/为 数据 库 名 赋 初 值 
/为 调试 信息 赋 初 值 


// 导 入 ADODB 类 库 
/生成 数据 库 连接 对 象 


让 (Sthis->dbType 一 "mysql || Sthis->dbType 一 'mssql) { /如 果 为 MySQL 数据 库 或 者 SQL Server 数据 库 


S$this->connID->Connect($this->host, $this->userName, $this->pwd. $this->dbName): 


if (Sthis->dbType — ‘mysql) { 
Sthis->connID->Execute('set names gb2312"): 
} 


} elseif (Sthis->dbType 一 'ado_aceess) { 


/通过 Connect0 方 法 建立 与 数据 库 的 连接 
// 设 置 数据 库 编码 
// 如 果 为 Access 数据 库 


// 在 连接 Access 数据 库 时 ， 编 写 连 接 语 句 一 定 要 注意 空格 的 使 用 ， 必 须 严格 执行 ， 否 则 很 可 能 导致 连接 失败 
Sthis->connID->Connect(Driver={Microsoft Access Driver (*.mdb)}:Uid=" $this->userName.'; Pwd= Sthis->pwd .'; 


Dbq= realpath($this->dbName).':"): 
j else{ 
retum false: 
7 
S$this->connID->debug = $this->isDebug: 
retum $this->connID: 


/是 否 调试 
/返回 数据 库 连接 对 象 
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function closeConnID |{ 
y @$this->connID->Disconnect|: /关闭 与 数据 库 的 连接 
} 
(4) 如 果 要 通过 封装 的 ConnDB 类 连接 数据 库 ， 必 须 对 类 进行 实例 化 ， 同 时 向 类 中 传递 参数 ， 最 终 返回 连 
接 标识 ， 该 操作 被 存储 于 config.inc.php 文件 中 。 在 该 文件 中 完成 数据 库 连 接 类 的 实例 化 ， 返 回 连接 的 标识 ， 同 
时 数据 库 操作 类 的 实例 化 也 在 该 文件 中 完成 ， 其 代码 如 下 : 


0 // 初 始 化 SESSION 变量 
require_once 'ConnDB.php'; // 包 含 数据 库 连 接 类 文件 
require_once 'AdminDB.php'; // 包 含 数据 库 操作 类 文件 
/JSconnDB = new ConnDB('access',",",",'data/db_messages.php'false); /连接 没有 密码 的 Access 数据 库 
$connDB = new ConnDB(‘ado_access',",",mrsoft','data/db_messages.php'.false); ” // 连 接 Access 数据 库 

$conn = $connDB->getConnID0: /返回 连接 标识 

S$adminDB = new AdminDB(); /实例 化 数据 库 操作 类 


(5) 新 建 聊天 室 头 文件 top.php， 通 过 include _ once 语句 包含 config.inc.php 文件 ， 返 回 数据 库 的 连接 标识 
和 数据 库 操作 类 的 实例 化 对 象 ， 在 该 文件 中 判断 当前 用 户 的 权限 ， 根 据 不 同 的 权限 输出 不 同 的 内 容 ， 其 关键 代 
码 如 下 : 


< 
ne 人 /包含 实例 化 文件 


人 

if($_SESSION["ne"]!="){ 
$arr=$adminDB->executeSQL("select * from tb_puser where usemc=".$_SESSION["nc"]."",Sconn); 
这 $arr[0][5] 1) 


| 。。 &nbsp:<a href-"setwordnullphp"> 清 空 聊 天 记录 </a>&nbsp: 
hp 


php 
if($_SESSION["ne"]!="){ 
?> 


|&nbsp;<a href-"logout.php"> 退 出 聊天 室 </a>&nbsp:| 
<?php 
} 


?> 


国 秘笈 心 法 


心 法 领悟 516: 通过 ADODB 类 库 操作 具有 密码 的 Access 数据 库 。 
在 通过 ADODB 类 库 操作 Access 数据 库 时 ， 如 果 Access 数据 库 没 有 设置 密码 ， 那 么 设置 Access 数据 库 的 
类 型 为 access; 如 果 Access 数据 库 设 置 了 密码 ， 那 么 Access 数据 库 的 类 型 必须 设置 为 ado_access。 


实例 517 趣味 指数 : 傅 塘 请 良 | 
实例 说 明 


在 本 实例 中 讲解 ADODB 操作 Access 数据 库 方法 的 封装 。 在 聊天 室 的 用 户 登录 模块 中 ， 应 用 数据 库 操作 
AdminDB 中 的 executeSQL() 方 法 完成 登录 用 户 的 验证 和 登录 信息 的 添加 操作 ， 其 运行 效果 如 图 11.15 所 示 。 
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[ 


日 用 户 本 好 
中东 这 要 登录 信息 ( * 广 址 - 瑟 录 过 称 地 不 同 ) 


下 室 合用 志 南 : 
| 


图 关键 技术 


用 户 登录 操作 的 完成 应 用 AdminDB 类 中 的 executeSQL( 方 法 , 在 该 方法 中 可 以 执行 查询 、 添 加 、 更 新 和 删 
ee AdminDB.php 文件 的 代码 如 下 : 
< 


class AdminDB{ 
function executeSQL ($sql, SconnID){ 
S$sqlType = strtolower(substr(trim($sql), 0, 6)); /| 提取 SQL 语句 的 类 型 
Srs = $connID->Execute($sq]); // 执 行 SQL 语句 
if($sqlType — 'select) { // 如 果 是 select 查询 
SarrayData = $rs->GetRows(); // 返 回 查询 记录 集 
Hf (count($arrayData) — 0 | $rs 一 false) { // 如 果 没 查询 到 或 发 生 错误 
return false; /返回 FALSE 
}else{ /否则 
return $arrayData; // 返 回 记录 集 
} 
} clseif ($sqlType 一 'insert || $sqlType — ‘update’ || $sqlType = 'delete') { /如 果 执 行 插入 、 更 新 或 删除 语句 
retum $rs; /返回 语句 执行 状态 , 即 成 功 返回 TRUE, 失败 返回 FALSE 
j} else{ 
retum false; // 如 果 不 是 上 述 查询 ， 则 返回 FALSE 


} 
} 


} 
在 实例 516 中 已 经 介绍 过 ， 该 类 的 实例 化 操作 同样 存储 于 config.inc.php 文件 中 ， 返 回 对 象 为 gadminDB。 
图 设计 过 程 
(1) 创建 index.php 文件 ， 设 置 聊天 室 的 登录 页 面 ， 通 过 form 表单 将 用 户 登录 信息 提交 到 saveuser.php 文 


件 中 进行 处 理 ， 同 时 创建 验证 用 户 名 是 否 被 占用 的 按钮 ， 调 用 JavaScript 脚本 中 的 open_chkne0 方 法 验证 用 户 名 


是 否 可 用 ， 其 关键 代码 如 下 : 

<?php 
include_once("top.php"): // 包 含 头 文件 

?> 

<form name="forml" method="post" action="saveuser php" onsubmit=—"return chkinput(this)"> 
<input type="text" name="usermne" size="15" class="inputess" maxlength="50"> 
<input type="button" value=" 是 否 已 用 " onClick="open_chkne(forml.useme.value)" class="buttoncss"> 
<select name="userhead" onchange="javascriptchange_ head0"> 


<?php 
for(Si=0:$i<=11:$itH{ 
> 


<option value="<?php echo("images/head/".$i".gif"):?>"> 头 像 <?php echo $i?></option> 
php 


</select> 
<input type="submit" name="submit" class="buttoncss" value=" 进 入 ">&nbsp:&nbsp: 
<input type="reset" class="buttoncss" value=" 重 写 "> 

</form> 


> 
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(2) 在 js/checkjs 文件 的 open_chknc0 方 法 中 调用 chkusernc.php 文件 ， 验 证 提交 的 用 户 名 是 否 被 占用 ， 其 
关键 代码 如 下 : 


<?php 
Snc=trim($_GET[ne]): 
ifSnc—"){ 
echo "请 输入 用 户 上 昵称 !"; 
}else{ 
Sinfo=$adminDB->executeSQL("select * from tb_puser where useme=". $nc."",Sconn); 
这 !$info){ 
echo " 菇 喜 您 ,该 昵称 未 被 占用 !"; 
jelse{ 
echo "对 不 起 ,该 昵称 已 被 占用 !"; 
} 


3) 新 建 saveuser.php 文件 ， 验 证 登录 用 户 名 是 否 被 占用 ， 如 果 用 户 名 可 用 ， 将 用 户 登录 信息 存储 到 指定 
数据 表 中 ， 并 且 跳 转 到 聊天 室 主页 面 ， 否 则 提示 用 户 名 不 可 用 ， 或 者 用 户 登录 失败 ， 其 关键 代码 如 下 : 
<Iphp 


include_once("conn/config.ine.php"); // 包 含 数据 库 连接 、 操 作 类 的 实例 化 文件 
$usemc=trim($_POST[usemc]): /获取 提交 的 用 户 名 
$sql=$adminDB->executeSQL("select * from tb_puser where usernc=".$userne."",$conn); // 验 证 用 户 名 是 否 被 占用 
这 $sqD){ 

人 '<script language=javascript>alert(' 对 不 起 ， 该 昵称 已 被 其 他 用 户 使 用 !"):history.back0;</script>"; 


yoke{ 
Slogintime=date("Y-m-j H:i:s"); // 定 义 时 间 
Suserhead=$_POST[userhead]; 
Sonline=1; 
Sip=getenv("REMOTE_ADDR"); /获取 下 
S$email=trim($_POST[email]); /获取 用 户 提交 的 E-mail 
Smark=0; 
Snowtime=time(); /定义 时 间 恰 
S$arr=$adminDB->executeSQL("insert into tb_puser(useme,logintime,ip,email.mark.userhead,online,nowtime) values (‘$userme','$logintime','$ip', 
‘$email','Smark','$userhead','$online','S$nowtime’)",$conn); // 执 行 用 户 信息 的 添加 操作 
这 Sarn{f 
$_SESSION["ne"]=$useme; /用 户 登录 成 功 后 将 用 户 名 赋 给 SESSION 变量 
echo "<script>window.location href='chat.php':</script>"; // 跳 转 到 聊天 室 主页 
yelse{ 
echo "添加 失败 ! "; 
} 
> 
力 秘笈 心 法 


心 法 领悟 517: 使 用 getenv0 函 数 获取 客户 端的 了 人 P 地 址 。 
在 本 实例 中 ， 应 用 getenv0 函 数 获取 客户 端的 IP 地 址 ， 其 作用 与 $_ SERVER[REMOTE ADDR'] 是 相同 的 。 


高 级 | 
实例 518 趣味 指数 : 要， 
图 实例 说 明 


聊天 室 的 主页 面 由 头 文件 top.php、 尾 文件 bottom.php、 发 布 聊天 信息 chatphp、 聊 天 内 容 listchat.php 和 聊 
天 参与 者 listuserphp 共 5 个 部 分 组 成 ， 其 运行 效果 如 图 11.16 所 示 。 
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Ma 驯 天 
ET El 
[ 
日 7 得 好 明日 科 扶 名 天 齐 | 当 商用 户 : or 
条 天 内 容 : 罗兰 与 者 
四 [tsett ] 对 【 所 有 人 ] 说: 《2014-09-64 16-01 和 os: Dams 0 
问题 解决 了 Hr met 
[EE 
请 二 入 则 天 内 容 : 
ceess 划 可 大 的 应 用 技 枯 | o 
用: 
EH 55 重 写 : 9 


上 设 为 面 页 | 收 基 本 站 | 联系 站 长 | 刷新 页 面 | 
站 明日 科技 在 二 论坛 】 版 权 所 有 训 林 光明 日 科技 有 限 公司 | 未 经 振 权 禁止 复制 或 兴 立 错位 | 


图 11.16 ”聊天 室 主页 面 


图 关键 技术 


在 聊天 室 的 主页 面 中 ,通过 include 语句 包含 网 站 的 头 文件 和 尾 文件 ; 聊天 内 容 的 编辑 和 聊天 对 象 的 选择 在 
聊天 室 主页 文件 chat.php 中 设置 ， 聊 天 内 容 和 聊天 参与 者 的 输出 则 是 在 独立 的 文件 中 编写 ， 应 用 这 ame 框架 载 
入 到 聊天 室 主页 面 chart.php 中 ， 其 关键 代码 如 下 : 


<div align="center"> 

<iframe frameborder="0" id="center" name="center" scrolling="Yes" sre="listchat.php" style="HEIGHT: 220: VISIBILITY: inherit; WIDTH: 
580px; Z-INDEX: 2"> </iframe> 
</div> 
<div align="center"> 

<iframe frameborder="0" id="right" name="right" scrolling="Yes" sre="listuser.php" style="HEIGHT: 360; VISIBILITY: inherit; WIDTH: 160px; 
Z-INDEX: 2"> </iframe> 
</div> 


图 设计 过 程 
(1) 在 聊天 室 主页 面 chat.php 中 ， 首 先 通过 include 语句 包含 网 页 头 文件 top.php， 并 判断 当前 用 户 是 否 为 
非法 登录 ， 如 果 是 则 给 出 提示 信息 并 跳 转 到 聊天 室 登 录 页 面 。 然 后 通过 fame 框架 载 入 聊天 内 容 和 聊天 参与 者 


输出 文件 。 最 后 创建 form 表单 ， 定 义 聊 天 内 容 的 编辑 框 和 聊天 对 象 的 选择 框 ， 将 聊天 信息 提交 到 saveword.php 
文件 中 进行 处 理 。chat.php 的 关键 代码 如 下 : 


<form action="saveword.php" method="post" name="form_bbs" id="form_bbs” onsubmit="retum chkinput(this)"> 
<textarea name="bbs_content" cols="85" rows="6" class="inputess"></textarea> 
<div align="center"> 发 送 给 : 
<input type="text" name="touser" size="12" disabled="disabled" value=" 
<input type="text" name="touser"size="12" disabled="disabled"value=" 
<?php 
$usemc = trim ( $_SESSION ["ne"] ): 
Sinfo = $adminDB->executeSQL ( "select * from tb_puser where userne=" . $useme . "", $conn ); 
证 (Sinfo [0] [5]— 1) { 
if($_SESSION ["sne"]—="") { 
echo "所 有 人 "; 
Yelse{ 
echo $_SESSION ["sne"]: 


S$infoc = $adminDB->executeSQL ( "select count(*) as total from tb_puser where online=1 and mark=1", $conn ): 
if ($infoc [0] [total] — 0) { 
echo "请 选择 发 送 人 "; 


{ 
if($_SESSION ["sne"] = "") { 
echo "请 选择 发 送 人 ": 
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}else{ 
echo $_SESSION ["sne"]: 
} 
} 
} 
>> 
<input type="hidden" name="touserl"value=" 
<?php 


Suseme =trim ($ SESSION ["ne"] ); 
Sinfo = $adminDB->executeSQL ( "select * from tb_puser where useme=" . Suseme . ™", $conn ): 
if($info [0] [5]—= D { 

if($_SESSION ["sne"]—"") { 


echo "所 有 人 "; 
}else { 
echo $_SESSION ["sne"]: 
} 
} else { 
让 (Sinfoc [total] = 0) { 
echo "请 选择 发 送 人 "; 
}else { 
if($_SESSION ["snc"] =—"") { 
echo "请 选择 发 送 人 "; 
}else{ 
echo $_SESSION ["sne"]: 
} 
. 


} 

?>"> &nbsp:&nbsp: 
<input type="submit" name="submit" value= "发送 " class="buttoncss" />&nbspi&nbsp: 
<input name="reset" type="reset" class="buttoncss" value=" 重 写 "> 


</form> 
(2) 新 建 saveword.php 文件 ， 将 聊天 信息 存储 到 指定 的 数据 表 中 ， 其 代码 如 下 : 
<?php 
ee ("conn/config.inc.php"); // 包 含 配置 文件 
S$fromuser = trim ( $_SESSION ["ne"] ); /获取 登录 用 户 名 称 
$sql = $adminDB->executeSQL ( "select * from tb_puser where usernc=" . $fromuser . "", Sconn ); /判断 用 户 是 否 存在 
if(! $sq)) { 
echo "<script>alert(' 对 不 起 ,等 待 时 间 过 长 ， 请 重新 登录 !");window.location href='logout.php';</script>"; 
exit 0: 
} 
Stouser = $_POST ['touserl']: 
让 (Stouser 二 "所 有 人 ") { 
Stouser = "all"; 


} 
Scontent =$_POST [bbs_content]; 
Spubtime = date ( "Y-m-i H:i:s" ); 
Snowtime = time (; 
Sarr = $adminDB->executeSQL ( "insert into tb_message(touser,fromuser,content.pubtime.nowtime) values ('$touser','$fromuser’, '$content', '$pubtime’, 
‘$nowtime’)", $conn ); 1/ 执行 信息 的 添加 操作 
证 (SarD { 
echo "<seript>window .location href='chat.php':</script>"; 
}else{ 
echo "添加 失败 1 ":; 
} 


了 


(3) 新 建 listuser.php 文件 ， 输 出 聊天 室 当 前 的 在 线 用 户 ， 并 通过 JavaScript 脚本 中 的 selectuser() 方 法 调用 
selectuser.php 文件 ， 完 成 聊天 对 象 的 选择 ， 其 关键 代码 如 下 : 


<script language="javascript"> 
function selectuser(x){ 
parent.form_bbs.touser.value=x; 
parent form_bbs.touserl.value=x; 
window.location href='selectuser.php?usernc="+x: 
} 
</script> 
<table width="120" border="0" align="center" cellpadding="0" cellspacing="0"> 
<?php 
Sarray = $adminDB->executeSQL ( "select * from tb_puser where online=1 ", Sconn ): 
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if(! Sarray) { 
> 


<t><td height="25" colspan="2"><div align="center"> 暂 无 人 登录 </div></td></tr> 
<?php 
} else{ 
> 


<tr onClick="javascript:selectuser( 所 有 人 ')" style="cursor: hand"> 
<td height="25" colspan="3" bgcolor="#99CCFF"><div align="center" class="STYLE1"> 发 给 所 有 参与 者 </div></td> 


</tr> 
<?php 
for($i= 0; $i < count ( Sarray ): $i++) { // 通 过 for 循环 输出 数据 库 中 的 数据 
Tey [Si] [useme] !=$_SESSION ["ne") { 
<tr onClick="j: 


有 ‘selectuser('<?php echo $array [$i] [1]; ?>)" style="cursor: hand"> 
<td width="25" height="25"><div align="center"><img src="<?php echo $array [$i] [6]; ?>" width="20" height="20" onMouseOver= 
"toolTip(<?php echo $array [$i] [1]; ?>", ‘<?php echo $array [$i] [3]; ?> ‘<?php echo Sarray [$i] [4]; ?>", ‘<?php echo $array [$i] [2]; 2>");" 
‘onmouseout= toolTip0; border=0></div></td> 

<td width="77" height="25"><div align="center"><?php echo $array [$i] [1]: ?></div> 


</td><?php 
} 
. 

} 

?> 
</table> 

(4) 新 建 selectuser.php 文件 ， 通 过 SESSION 定位 聊天 对 象 ， 代 码 如 下 : 
<php 
session_start(); // 初 始 化 SESSION 变量 
unset($_ SESSION['snc] ) ; 1/ 删除 SESSION 变量 中 的 值 
$_SESSION["sne"]=$_GET[usernc]:; // 根 据 超 链接 传递 的 变量 值 重 新 为 SESSION 变量 赋值 
echo "<script>window .location hre 人 istuserphp':</script>": 
> 


(5) 新 建 listchat php 文件 完成 聊天 信息 的 循环 输出 ， 其 关键 代码 如 下 : 
<table width="500" border="0" align="center" cellpadding="0"cellspacing="0"> 
<?php 
ciode ence ("function.php"); 
$sql = $adminDB->executeSQL ( "select + from tb_message ", $conn ); 
if($sq)) { 
for($i=0; $i< count ( $sql ); $i++) { // 通 过 for 循环 输出 数据 库 中 的 数据 
于 ($sql [Si] [1] = "all") { 
> 


<tr> 
<td height="20"><img sre="images/topic.gif’ width="10" height="9"></td> 
<td><div align="left"><font color="#3333FF">[&nbsp:<strong><?php echo $sql [$i] [4]; ?></strong>&nbsp:]&nbsp: 对 
[ &nbsp;<strong> 所 有 人 </strong>&nbsp:] 说 : &nbsp: <?php echo getday ( $sql [$i] [3] ); ?>&nbsp:)</font></div> 
</itd> 
</tr> 
<t> 
<td height="25" colspan="2"><div align="left">&nbsp:&nbsp:&nbsp:&nbsp:<?php echo unhtml ( $sql [$i] [2] ); ?></div></td> 
</tr> 
<php 
} else{ 
if($_SESSION ["ne"] 一 $sql [$ [1] || $_SESSION ["nc"] 一 Ssql[$i [4D) { 
> 


<t> 
<td width="36" height="20"><img sre="images/topic.gif" width="10" height="9"></td> 
<td><div align="left"><font color="#3333FF">[&nbsp:<strong><?php echo $sql [$i] [4]; ?></strong>&nbsp:]&nbsp: 对 
[&nbsp:<strong><?php echo $sql [$i] [1]; ?></strong>&enbsp;] 说 : &nbsp: (&nbsp;<?php echo getday ( $sql [$i] [3] ); ?>&nbsp:)</font></div> 
<hd> 

</> 

<t> 
<td height="25" colspan="2"><div align="left">é&nbsp;&nbsp;&nbsp:&nbsp:<?php echo unhtml ( $sql [$i] [21): ?></div> 
<htd> 

< 

<?php 
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} 
} 


ey 
</table> 
(6) 新 建 function.php 文件 ,编辑 自 定义 函数 unhtml0 对 聊天 室 中 输出 的 聊天 信息 进行 格式 化 ;编辑 getday0 

函数 计算 时 间 。 

心 法 领悟 518: 私 聊 功能 的 实现 。 

PHP 中 实现 私 聊 的 方法 有 多 种 ， 用 SESSION 实现 私 聊 相 对 简单 ， 本 聊天 室 中 私 聊 的 关键 代码 如 下 : 

人 |$_SESSION["nc"]—$info[fromuser] ){ 

/显示 私 聊 内 容 


<?php 


> 

上 述 简 短 的 代码 说 明了 实现 私 聊 的 原理 ，$_SESSION["ne"] 保 存 的 是 当前 登录 用 户 的 昵称 ，$info[touser] 表 
示 当 前 聊天 内 容 要 发 送 的 对 象 。 如 果 两 者 相等 ， 则 显示 出 该 聊天 内 容 ; 否则 不 显示 ， 或 者 在 
$_SESSION["nc"] 一 $info[ffomuser] 的 情况 下 也 显示 聊天 内 容 ， 这 种 情况 表示 发 送 用 户 可 以 看 到 自己 所 发 送 的 聊 
天 内 容 。 


力 实例 说 明 


在 聊天 室 模块 中 有 一 个 特殊 用 户 tsoft， 即 聊天 室 的 管理 者 ， 可 以 行使 聊天 室 的 管理 权限 ， 发 布 公告 消息 、 
清空 聊天 记录 。 管 理 员 登录 的 运行 效果 如 图 11.17 所 示 。 


11.17 聊天 室 管理 员 登 录 


力 关键 技术 


在 聊天 室 管理 员 登 录 页 面 中 , 关键 是 通过 AdminDB 类 中 的 executeSQL( 方 法 判断 输入 的 用 户 名 和 密码 是 否 
正确 ， 如 果 正 确 则 说 明 是 管理 员 ， 将 该 用 户 名 存储 到 SESSION 变量 中 。 只 有 当前 用 户 具 备 了 管理 员 的 权限 才 可 
以 执行 清空 聊天 记录 的 操作 。 

图 设计 过 程 
(1) 新 建 admin_login.php 文件 ， 创 建 form 表单 将 用 户 名 和 密码 提交 到 admin_login_ok.php 文件 中 ， 完 成 
管理 员 登 录 操 作 。 
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(2) 新 建 admin login_ok.php 文件 ， 通 过 AdminDB 类 中 的 executeSQL( 方 法 判断 输入 的 用 户 名 和 密码 是 
否 正 确 ， 如 果 正 确 则 将 当前 用 户 名 赋 给 SESSION 变量 ， 并 跳 转 到 聊天 室 主页 面 行使 管理 员 的 权限 ， 其 关键 代码 
如 下 


<?php 
include_once("conn/config ine php"); 
i($_POST['user]!="" | $_POST['pass]!="" ){ 
$sql=$adminDB->executeSQL("select * from tb_puser where useme=".$_POST['user]." and pwd=".$_POST['pass].™",Sconn); 
这 $sqD{ 
$_SESSION["ne"]-$_POST[user]: 
echo "<script>alert( 管 理 员 登录 成 功 !):window location href='chat php':</script>"; 

jelsef 

echo "<seript>alert( 管 理 员 登 录 失 败 !);window ,location href-admin login php':</seript>"; 
} 
Yelse{ 

echo "<script>alert( 管 理 员 用 户 名 和 密码 不 能 为 空 !):window.location href='admin_login php';</script>"; 
2? 


> 
(3) 新 建 setwordnull.php 文件 ， 判 断 如 果 当 前 用 户 是 管理 员 则 执行 清空 聊天 记录 的 操作 ， 其 代码 如 下 : 
<?php 

include_once("conn/config inc.php'): 

Susemc=$_SESSION["ne"]: 

if($usemel=" | Suseme 一 tsoft ){ 

$sql=$adminDB->executeSQL("delete from tb message ".Sconn); 

if($sqD){ 

Se "<script>alert( 聊 天 记录 删除 成 功 ! "):window .location href='chat php';</script>"; 


} 

jelsef 

echo "<script>alert( 不 允许 非法 操作 ):window ,location href='admin_login.php';</script>"; 
} 


1 


(4) 新 建 logout.php 文件 ， 执 行 用 户 或 者 管理 员 的 退出 功能 ， 其 代码 如 下 : 
<?php 
include_once("conn/config ine.php"): 
Susemc=$_SESSION["ne"]: 
if($useme=—"tsoft"){ 
unset ( $_SESSION[snc] ) : 
unset($_SESSION[ne] ) ; 
echo "<script>alert( 退出 聊天 室 ):window location href='index.php':</script>"; 
jelsef 
$sql=$adminDB->executeSQL("delete from tb_puser where useme=". $usermne.™",$conn): 
if($sqD){ 
unset ( $_SESSION['sne’] ) : 
unset ($_SESSION[me] ) : 
echo "<script>alert( 退出 聊天 室 ):window.location href='index.php':</script>"; 


) 
> 


图 秘笈 心 法 


心 法 领悟 519: 定时 刷新 聊天 室 的 聊天 信息 和 在 线 列 表 。 
定时 刷新 聊天 室 的 聊天 信息 和 在 线 列表 应 用 的 是 <meta> 标 签 的 http-equiv 属性 和 content 属性 。 通 过 
http-equiv 设置 refresh 执行 刷新 ， 通 过 content 设置 刷新 的 时 间 间 隔 ， 其 代码 如 下 : 


<meta http-equiv="refresh" content="5" /> 
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12.1 连接 Oracle 数据 库 


本 节 将 介绍 在 PHP 中 如 何 实现 与 Oracle 数据 库 的 连接 ， 这 里 分 别 讲解 通过 Oracle 函数 库 和 ADODB 连接 
及 操作 Oracle 数据 库 。 


连接 Oracle 数据 库 高 级 


1 
| 
趣味 指数 : 寅 全食 从 | 


力 实例 说 明 


PHP 连接 Oracle 数据 库 的 方法 很 多 ， 这 里 介绍 通过 PHP 中 自 带 的 Oracle 函数 库 来 完成 对 Oracle 数据 库 的 
操作 。 在 本 实例 中 ,应 用 oci connectO 函 数 连接 Oracle 数据 库 ， 然 后 应 用 oci_parse0 函 数 执行 查询 语句 ， 最 终 通 
过 oci_fetch_array0 函 数 和 while 语句 完成 数据 库 中 数据 的 循环 输出 ， 其 运行 结果 如 图 12.1 所 示 。 


2 二 站 


EL le 


图 12.1 oci_connect0 函 数 连接 Oracle 数据 库 


力 关键 技术 


在 PHP 的 Oracle 函数 库 中 提供 有 完成 对 Oracle 数据 库 操作 的 函数 ,这 里 只 对 本 实例 中 应 用 的 函数 进行 详细 
介绍 。 


(1) oci_connect0 函 数 建 立 一 个 到 Oracle 服务 器 的 连接 ， 返 回 一 个 连接 标识 符 ， 其 语法 如 下 : 


Tesource oci_connect( string username, string password [, string db [. string charset [. int session_mode]]] ) 


oci_connect0 函 数 的 参数 说 明 如 表 12.1 所 示 。 


表 12.1 oci_connect() 函 数 的 参数 说 明 
参数 说 明 
Username 必 选 参数 ， 指 定数 据 库 中 的 用 户 名 
_password 必 选 参数 ， 指 定数 据 库 中 用 户 的 密码 
可 选 参数 ， 包 含 要 连接 的 本 地 Oracle 的 实例 或 者 在 msnames.ora 中 条 目的 名 字 。 如 果 没有 指定 该 参数 ，PHP 
使 用 环境 变量 ORACLE _SID 〈Oracle 实例 ) 或 TWO_TASK (tnsnames.ora) 来 确定 连接 哪 一 个 数据 库 
使 用 Oracle 服务 器 9.2 或 更 高 版 本 时 ， 可 以 指定 charset 参数 ， 被 用 于 新 的 连接 。 如 果 使 用 低 于 9.2 版 本 的 
Oracle 服务 器 ， 本 参数 将 被 忽略 并 以 NLS_LANG 环境 变量 蔡 代 
该 参数 自 版 本 1.1 起 可 用 并 接受 如 下 值 : OCIL DEFAULT、OCI SYSOPER 和 OCI SYSDBA。 如 果 指 定 
session mode |OCI SYSOPER 或 OCI SYSDBA 其 中 之 一 ，oci_ connectO 函 数 将 尝试 使 用 外 部 认证 信息 建立 特权 连接 。 特 
权 连 接 默认 被 禁止 ， 如 果 要 启用 ， 需 要 将 oci8.privileged_connect 设置 为 On 


db 


charset 
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[人 说 明 : 对 oci_connectO 函 数 用 同样 的 参数 第 二 次 及 之 后 的 调用 将 返回 第 一 次 调用 所 返回 的 连接 句柄 。 即 对 
一 个 句柄 发 出 的 查询 也 适用 于 另 一 个 句 枉 ， 因 为 它们 是 同一 个 句 枉 。 如 果 需 要 两 个 句柄 在 事务 上 互 
相隔 离 ， 则 使 用 oci new_connectO 函 数 蔡 代 。 

(2) oci_parse() 函 数 配置 Oracle 语句 预备 执行 ， 其 语法 如 下 : 
Tesource oci_parse( resource connection, string query ) 
参数 说 明 : 
connection: 必 选 参数 ， 数 据 库 连接 成 功 后 返回 的 连接 标识 符 。 
query: 必 选 参数 ， 执 行 的 SQL 语句 。 
oci parse0) 函 数 是 最 常用 的 函数 ， 在 操作 Oracle 数据 库 时 ， 无 论 是 执行 查询 、 修 改 、 删 除 或 更 新 操作 ， 该 函 

数 是 必须 使 用 的 ,只 有 通过 该 函数 在 connection 上 配置 query 并 返回 语句 标识 符 后 , 才 可 以 用 于 其 他 函数 的 操作 ， 

例如 oci_bind_by_name0 〇 函数 、oci_execute() 函 数 。oci_parse0 函 数 在 出 错时 返回 FALSE。 


_Bg 技巧 : oci_parse 函 数 并 不 验证 参数 query。 验 证 参数 query 是 否 为 合法 的 SQL 或 者 PL/SQL 语句 的 唯一 方 
法 是 执行 语句 。 


(3) oci_execute(0 函 数 执行 一 条 之 前 被 解析 过 的 语句 (参见 oci_parse0 函 数 ) 。 如 果 成 功 则 返回 TRUE; 否 
则 返回 FALSE， 其 语法 如 下 : 


bool oci_execute ( resource stmt [, int mode] ) 

参数 说 明 : 

stmt: 必 选 参数 ， 获 取 的 语句 标识 符 。 

mode: 可 选 参数 ，mode 允许 定义 执行 模式 (默认 是 OCL COMMIT ON _SUCCESS) 。 如 果 不 需 要 将 语句 
自动 提交 ， 则 把 mode 设 为 OCL DEFAULT。 


< 注意 : 在 使 用 OCI DEFAULT 模式 时 将 建立 一 个 事务 ,事务 会 在 关闭 连接 或 者 脚本 结束 时 自动 回 滚 。 需 要 
明确 调用 oci_commitO 函 数 来 提交 事务 ， 或 者 调用 oci rollback0 函 数 中 止 事务 。 


(4) oci_fetch_array0 函 数 ， 从 结果 集中 获取 一 行 作为 关联 数组 或 数字 数组 或 者 二 者 兼 有 。 如 果 没 有 更 多 行 
则 返回 FALSE， 其 语法 如 下 : 


array oci_fetch_array( resource statement [. int mode] ) 
oci_fetch_arrayO 函 数 中 可 选 的 第 2 个 参数 mode 是 一 个 常量 ， 该 参数 的 默认 值 是 OCL BOTH， 其 可 选 值 如 
表 12.2 所 示 。 


表 12.2 oci_fetch_array() 函 数 的 参数 mode 的 可 选 值 


参数 说 了 明 
OCI BOTH 得 到 一 个 同时 包含 关联 和 数字 索引 的 数组 
OCI ASSOC 得 到 关联 索引 (如 同 oci_fetch_ assocO) 
OCI NUM 得 到 数字 索引 (如 同 oci_fetch rowO) 


创建 一 个 空 元 素 为 NULL 字段 
返回 LOB 的 值 的 描述 


OCI RETURN NULLS 
OCI RETURN LOBS 


oci_fetch_array0 函 数 是 oci_fetch_row0 函 数 的 扩展 版 本 。 除 将 数据 以 数字 索引 方式 存储 在 数组 中 之 外 , 还 可 
以 将 数据 作为 关联 索引 存储 ， 用 字段 名 作为 键 名 。 

如 果 结 果 中 有 两 个 或 以 上 的 列 具 有 相同 的 字段 名 ， 最 后 一 列 将 优先 。 要 访问 同名 的 其 他 列 ， 必 须 用 该 列 的 
数字 索引 或 给 该 列 起 个 别名 。 对 于 有 别名 的 列 ， 不 能 再 用 原来 的 列 名 访问 其 内 容 。 
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(5) oci_closeO 函 数 关闭 Oracle 连接 ， 成 功 返 回 TRUE， 和 否则 返回 FALSE， 其 语法 如 下 : 


bool oci_close( resource connection ) 
通过 上 述 5 个 函数 即 可 完成 Oracle 数据 库 的 连接 、 读 取 和 关闭 操作 ,再 以 while 语句 为 辅 , 可 以 完成 Oracle 
数据 库 中 数据 的 循环 输出 。 
图 设计 过 程 
(1) 创建 conn 文件 夹 ， 编 写 conn php 文件 ， 应 用 oci_connect0 函 数 连接 用 户 名 为 system， 口 令 为 mrsoft 
的 Oracle 数据 库 。 数 据 库 名 称 为 oracle， 也 可 以 设置 为 空 ， 因 为 Oracle 数据 库 服 务 器 在 本 机 上 。conn.php 文件 
的 代码 如 下 : 
<Ipbp 
/连接 数据 库 的 名 称 为 oracle， 用 户 名 是 system， 密 码 是 mrsoft 
/如 果 Oracle 数据 库 服务 器 与 PHP 程序 处 于 同一 机 器 中 ， 在 连接 时 数据 库 名 称 可 以 省 略 
Seonnoci comneett syskm "mrsoft" "oracle", "vif") or dnoci errorO); 
(2) 创建 index.php 文件 ， 通 过 include 语句 包含 数据 库 连 接 文件 ， 应 用 Oracle 函数 库 中 的 函数 和 while 语 
句 完成 数据 库 中 数据 的 循环 输出 ， 其 关键 代码 如 下 : 


<?php 

include("conn/conn.php"); // 包 含 数据 库 连接 文件 
$query="select * from tb_user "; /定义 SQL 语句 
Sresult=oci_parse($conn.$query); // 配 置 Oracle 语句 

S$r = oci_execute($result, OCI DEFAULT); /执行 SQL 语句 
while($row=oci_fetch_array($result,OCI RETURN_ NULLS)){ 1/ 循环 输出 数组 中 的 数据 


> 

<u> 

<td align="center" bgcolor="#FFFFFF"><?php echo $row[0]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[11:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[2]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[3]:?></td> 
<td align="center" bgeolor="#FFFFFF"><?php echo $row[4]:?></td> 

</tr> 

<?php 


} 
oci_close($conn); 
> 


力 秘笈 心 法 
心 法 领悟 520: Oracle 函数 库 中 函数 使 用 的 前 提 条 件 。 
(1) Windows 用 户 在 Oracle 8.1 版 本 以 上 才能 使 用 php_oci8.dll。 
(2) 在 php.ini 文件 中 ， 将 ; extension=php_oci8.dll 和 ; extension=php_oracle.dll 前 面 的 分 号 去 掉 ， 保 存 后 重 
新 启动 Apache 服务 器 。 


高 级 | 
实例 521 趣味 指数 ， 妇女 女 页， 
图 实例 说 明 


ADODB 是 一 种 PHP 存 取 数 据 库 的 中 间 函 式 组 件 ， 可 用 于 连接 很 多 不 同 的 数据 库 。 本 实例 将 介绍 通过 
ADODB 连接 及 操作 Oracle 数据 库 的 方法 ， 完 成 数据 库 中 数据 的 读 取 和 添加 操作 ， 其 运行 结果 如 图 12.2 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


页 | 员工 录入 | 考 台 各 理 
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图 12.2 ADODB 操作 Oracle 数据 库 


上 说 明 : 因为 ADODB 属于 第 三 方 组 件 ， 所 以 在 本 书 的 光盘 中 没有 提供 adodb 类 库 文件 ， 需 要 读者 自行 下 载 
并 复制 到 本 章 的 12 文件 夹 下 ， 并 且 命 名 为 adodb5， 然 后 才 可 以 运行 本 章 的 实例 。 


力 关键 技术 


使 用 ADODB 连接 数据 库 系 统 应 用 ADONewConnection0 〇 函数 ; 如果 选择 持久 化 连接 数据 库 则 使 用 PConnectO 
函数 ， 如 果 选 择 非 持 久 化 连接 则 使 用 ConnectO 函 数 。 
(1) ADONewConnection0 函 数 用 于 连接 数据 库 系统 ， 其 语法 如 下 : 


ADONewConnection($databaseType) 
参数 $databaseType 表示 要 连接 的 数据 库 系 统 的 名 称 ， 如 mysql、oci8 等 。 


(2) PConnect0 函 数 实现 与 数据 库 持久 化 连接 ， 其 语法 如 下 : 
PConnect(Shost[$user],[Spassword],[Sdatabase]) 


参数 说 明 : 

$host; 数据 库 系统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
$user: 数据 库 用 户 名 。 

Spassword: 数据 库 密码 。 

$database: 使 用 到 的 数据 库 。 


(3) Connect0 函 数 ， 实 现 与 数据 库 非 持 久 化 连接 ， 其 语法 如 下 : 
Connect(Shost,[$user].[$password].[$database]) 


参数 说 明 : 

$host: 数据 库 系统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
Suser: 数据 库 用 户 名 。 

$password: 数据 库 密码 。 

$database: 使 用 到 的 数据 库 。 


-GBS 技巧 : 持久 化 连接 和 非 持 久 化 连接 的 区 别 : 持久 化 连接 不 用 每 次 都 创建 新 连接 ， 可 以 增加 程序 的 执行 速度 ， 
但 是 有 些 数据 库 不 支持 此 函数 ， 那 么 就 需要 使 用 ConnectO 函 数 来 替代 PConnectO 函 数 。 


(4) 应 用 execute0 函 数 执行 SQL 语句 ， 应 用 EOF 变量 、while 语句 和 MoveNext0 函 数 完成 数据 的 循环 输 
出 。 有 关 ADODB 类 库 中 函数 的 详细 讲解 请 参考 第 13 章 。 


设计 过 程 
(1) 将 下 载 的 ADODB 类 库 命名 为 adodb5， 存 储 于 12 文件 夹 下 ， 并 且 在 12 文件 夹 下 创建 文件 夹 521 作 
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为 实例 的 根 目录 。 
(2) 在 实例 根 目录 521 下 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 应 用 ADONewConnection0 和 Connect0 


函数 连接 Oracle 数据 库 ， 其 代码 如 下 : 
<?php 


include('./adodb5/adodb.inc.php): // 载 入 ADODB 
$conn = ADONewConnection('oci8"); // 建 立 一 个 Oracle 连接 
Sconn->Connect("oracle", "system", "mrsoft"); // 连 接 Oracle 数据 库 ， 用 户 名 为 system， 口 令 为 mrsoft 


?> 
(3) 创建 ndex.php 文件 ， 通 过 include 语句 包含 数据 库 连 接 文件 ， 完 成 数据 库 中 数据 的 循环 输出 ， 并 且 创 
建 form 表单 ， 将 员工 信息 提交 到 index_ok.php 文件 中 完成 员工 信息 的 添加 操作 ， 其 关键 代码 如 下 : 


<?php 

if($_GET[conmn id]—"1"){ 

include_once ‘conn/conn.php'; // 载 入 数据 库 连接 文件 
$sqlstr = 'select * from tb_user //SQL 查询 语句 

Srst = $conn->execute ( $sqlstr ) or die (‘error: '. $conn->errorMsg 0 ); /执行 查询 语句 

while (!$rst->EOF ) { /hwhile 语句 循环 输出 结果 
> 

<t> 


<td align="center' bgcolor="#FFFFFF"><?php echo $rst->ficlds ['01:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312", "utf-8",$rst->ficlds ['1"]):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst->ficlds [2"]):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst->ficlds [3']):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo iconv("gb2312","utf-8",$rst->ficlds [4]):?><htd> 


<It> 
<2php 
Srst->MoveNext |; // 指 针 下 移 

Le ee 0: /关闭 连接 

$conn->close 0; 
: 

> 

(4) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 将 员工 信息 添加 到 Oracle 数据 库 中 ， 其 代码 如 下 : 
证 ("Content-type: text/html; charset=utf-8" ); // 设 置 文件 编码 格式 


include("conn/conn.php"); 
if($_POST['name]!=""){ 
$sql="insert into tb user(id,name,position,.age.dates) 
values(idsid .nextval,".iconv("utf-8","gb2312",$ POST['name"]).",".iconv("utf-8"."gb2312",$ POST['position"]). 
ge"]).",".iconv("utf-8","gb2312",$_POST['dates]).")"; 
S$rst= $conn->execute ( $sql ) or die ( ‘error: '. $conn->errorMsg (0 ); /| 执行 添加 语句 
if(Srst){ 
echo "<script>alert(' 信 息 添加 成 功 ! )):window.location.href='index.php?conn_id=1';</script>"; 
jelse{ 
echo "<script>alert( 信息 添加 失败 ! ):windwolocation href='index.php'</seript>"; 


‘iconv("utf-8","gb2312",.$ POST[a 


} 
yelse{ 

echo "<script>alert(' 请 输入 员工 信息 ! ");windwo.location href='index.php'</script>"; 
} 
?> 


图 秘笈 心 法 


心 法 领悟 521: ADODB 连接 Oracle 数据 库 的 关键 。 
(1) 必须 注意 ， 在 运用 ADONewConnection0 函 数 时 ， 指 定 的 参数 是 oci8。 
(2) 在 Connect0 函 数 中 ， 包 括 3 个 参数 : 第 1 个 参数 是 数据 库 名 称 ， 第 2 个 参数 是 用 户 名 ; 第 3 个 参数 
是 口令 。 
(3) 在 输出 数据 库 中 数据 时 ， 需 要 应 用 iconv0 函 数 对 输出 的 数据 进行 编码 格式 转换 ， 由 原来 的 GB2312 编 
码 转换 为 UTF-8 编码 。 
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A 高 级 | 
实例 522 趣味 指数 : 砍 页 友 妆 
图 实例 说 明 


在 本 实例 中 ， 仍 然 应 用 ADODB 操作 Oracle 数据 库 ， 在 完成 数据 库 中 的 数据 循环 输出 的 同时 ， 增 加 一 个 数 
据 库 中 数据 的 删除 操作 ， 通 过 超 链 接 删除 员工 信息 ， 其 运行 结果 如 图 12.3 所 示 。 
各 9 生理 纹 、 


八 11 MIINF 首页 | 员工 录入 | 考勤 各 理 
明日 图 蔬 “明日 软件 。“ 奖 低 条 例 


和 Wri : [2008-08-10 


ED 
图 12.3 ”删除 Oracle 数据 库 中 的 数据 


图 关键 技术 


本 实例 同样 应 用 ADODB 类 库 完成 对 Oracle 数据 库 的 连接 和 操作 ， 具 体 连接 方法 可 以 参考 实例 521， 这 里 
不 再 装 述 。 

(1) execute0 函 数 执行 SQL 语句 ， 并 返回 一 个 结果 集 (ADORecordSet 对 象 ) ， 失 败 则 返回 FALSE， 其 语 
法 如 下 : 
execute($sql[,$inputarr=false]) 

参数 $sql 指定 要 执行 的 SQL 语句 ， 参 数 $inputarr 设置 传 入 的 结合 变量 ， 如 果 没 有 设置 $inputarr， 则 $sql 为 
普通 的 SQL 语句 ， 那 么 execute0 函 数 的 格式 如 下 : 


S$connect->execute('select * from tb_user where id=1") 


如 果 设 置 了 $inputarr， 那 么 execute0 〇 函数 的 格式 如 下 : 


Sconnect -> execute('select * from tb_user where id = ?armray(SvD) 


(2) 要 对 结果 集 进行 操作 ， 首 先 要 确定 结果 集中 指针 的 位 置 ， 控 制 结果 集中 指针 的 方法 如 表 12.3 所 示 。 
表 12.3 ADODB 类 库 控制 结果 集中 指针 的 方法 


方 ” 法 说 明 
fields 变量 。 | 保存 当前 指针 所 指向 的 记录 
EOF 变量 。 | 记录 当前 指针 是 否 指向 最 后 一 条 记录 。 如 果 是 ， 则 返回 TRUE， 否 则 返回 FALSE 
MoveNext0 ”| 将 ADORecordSet (结果 集 ) 的 指针 下 移 一 位 。 成 功 则 返回 TRUE， 否 则 返回 FALSE 
将 ADORecordSet (结果 集 ) 的 指针 移动 到 指定 位 置 。 如 果 S$to 等 于 0， 则 指针 指向 结果 集 的 第 一 条 数据 ; 
如 果 $to 的 值 大 于 结果 集 ， 则 指针 指向 最 后 一 条 数据 。 注 意 ， 这 里 的 变量 $to 只 能 是 绝对 定位 
MoveFirstO ”| 将 指针 移动 到 第 一 条 数据 ， 等 同 于 Move(0) 


MoveLastO 将 指针 移动 到 最 后 一 条 数据 ， 等 同 于 Move(RecordCount0-1) 


Move($to) 
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力 设计 过 程 
这 里 在 实例 521 的 基础 上 增加 删除 数据 库 中 数据 的 功能 ， 其 具体 的 方法 如 下 : 


(1) 在 index.php 文件 中 为 输出 的 每 条 数据 添加 一 个 删除 超 链接 ， 链 接 到 delete_ok.php 文件 ， 将 数据 的 ID 
作为 参数 传递 到 delete_ok.php 文件 中 ， 其 关键 代码 如 下 : 
<a href="delete_ok.php?conn_id=<?php echo $rst->fields [0]; ?>"> 删 除 </a> 
(2) 创建 delete_ok.php 文件 ， 以 超 链接 传递 的 参数 值 为 条 件 ， 执 行 删 除 操作 ， 删 除数 据 表 指 定 的 记录 ， 其 
代码 如 下 : 


<?php 

header ( "Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
include("conn/conn.php"): // 包 含 数据 库 连 接 文件 
$sql="delete from tb_user where id=".$_GET['conn_id].™"; // 定 义 删除 语句 

Srst = $conn->execute ( $sql ) or die ( ‘error: '. Sconn->errorMsg 0 ): 。“// 执 行 删除 语句 

这 Srsb{ 


echo "<script>alert( 信息 删除 成 功 ! ):windowJocation href='index.php':</script>"; 
jelsef 

echo "<script>alert( 信息 删除 失败 ! ):windwo.location href='index.php'</script>"; 
?> 


国 秘笈 心 ; 
心 法 领悟 522: ADODB 类 库 。 


在 本 章 中 只 是 应 用 ADODB 类 库 连 接 及 操作 Oracle 数据 库 ， 其 实 ADODB 连接 和 操作 任何 数据 库 的 函数 、 
方法 都 是 相同 的 ， 有 关 ADODB 类 库 的 具体 运用 将 在 第 13 章 中 进行 详细 的 讲解 。 


12.2 操作 Oracle 数据 库 


PHP 对 Oracle 数据 库 有 很 好 的 函数 支持 ， 用 户 可 以 通过 这 些 函 数 像 操作 MySQL 数据 库 一 样 操作 Oracle 数 
据 库 。 


oy 


实例 523 : 趣味 指数 : 座 庚 次 安 


力 实例 说 明 


本 实例 应 用 PHP 和 Oracle 数据 库 创建 一 个 企业 用 户 管理 模块 ， 实 现 用 户 信息 的 添加 、 查 询 和 更 新 操作 。 运 
行 结果 如 图 12.4 所 示 。 


fID 损 二 用 P、 [2 司 到 


D RPS 到 名 和 氛 作 


12.4 企业 用 户 管理 操作 页 面 
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图 关键 技术 


本 实例 的 关键 是 应 用 oci bind by _name0 函 数 实现 对 Oracle 数据 库 的 操作 ， 完 成 数据 的 添加 、 查 询 和 更 新 操作 。 


oci_ bind by _name(0 函 数 绑 定 一 个 PHP 变量 到 一 个 Oracle 位 置 标识 符 ， 其 语法 如 下 : 
bool oci_bind_by_name( resource stmt, string ph_name, mixed &variable [. int maxlength [, int type]] ) 
oci_bind_by_name() 函 数 的 参数 说 明 如 表 12.4 所 示 。 


表 12.4 oci_bind_by_name() 函 数 的 参数 说 明 


参数 说 有明 

stmt 必 选 参数 ， 经 过 Oracle 解析 (oci_parse0 函 数 ) 后 的 语句 标识 符 

ph name 必 选 参数 ，Oracle 资料 表 上 的 字段 名 称 

variable 必 选 参数 ， 指 定 的 PHP 变量 

Ee 可 选 参数 ， 确 定 该 绑 定 的 最 大 长 度 ， 如 果 将 maxlength 设 为 -1，oci_bind_by_name0 函 数 会 用 variable 
变量 的 当前 长 度 确定 绑 定 的 最 大 长 度 

type 可 选 参数 ， 指 定 Oracle 使 用 的 描述 符 ， 指 定 的 描述 符 的 类 型 如 表 12.5 所 示 


表 12.5 oci_bind_by_name() 函 数 的 参数 type 的 可 能 值 


类 型 说 有 明 说 有明 
SQLT FILE BFILE SQLT INT 对 应 于 integers 
SQLT CFILE CFILE 对 应 于 VARCHARS 
SQLT_CLOB CLOB 对 应 于 RAW 列 
SQLT BLOB BLOB 对 应 于 LONG 列 
SQLT ROWID | ROWID 对 应 于 LONG RAW 列 
SQLT NTY 对 应 于 有 名 字 的 数据 类 型 对 应 于 游标 ， 是 由 oci_new_cursorO 函 数 创建 的 


[ED 说 明 : 如 果 要 绑 定 一 个 抽象 数据 类 型 (LOB/ROWIDJBFILE) ,需要 先 用 oci_new_deseriptor0 函 数 分 配 空间 。 
车 maxlength 没有 用 于 抽象 数据 类 型 ， 应 设置 为 -1。 


力 设计 过 程 

(1) 创建 index.php 文件 ， 编 辑 form 表单 ， 通 过 forml 提交 查询 的 员工 ID 将 数据 提交 到 本 页 ， 在 本 页 中 
完成 查询 操作 ; 创建 fprm2， 将 查询 结果 作为 form2 中 表单 元 素 的 默认 值 ， 通 过 form2 实现 对 员工 信息 的 更 新 操 
作 ， 将 数据 提交 到 index_ok.php 文件 中 完成 数据 的 更 新 操作 。 


(2) 创建 index_ok.php 文件 ， 获 取 form2 中 提交 的 员工 更 新 数据 ， 通 过 oci_bind by_name0 函 数 完成 数据 
的 更 新 操作 ， 其 代码 如 下 : 


?ph 

i ( "Content-type: text/html; charset=utf-8" ): // 设 置 文件 编码 格式 

include("conn/conn.php"): // 包 含 数据 库 连 接 文件 

if($_POST['Submit2]-—true){ // 判 断 提交 按钮 值 

$query="update tb_user set name=:muser, position=:mposition, age=:mage where id=:mid"; /定义 更 新 语句 
Sresult=oci_parse($conn, $query); /配置 Oracle 更 新 语句 
oci_bind by_name($result ':mid'. $S_ POST[hiddenField]): /添加 数据 


oci_bind_by_name(S$result, cmuser. $_POST[user]): 

oci bind by name(Sresult mposition', $ POST[position]): 

oci_bind_ by_name(Sresult “mage'. $_POST[age]): 

Sr=oci_execute(Sresult); /执行 更 新 语句 
这 $9{ 
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print "<script> alert (数据 更 新 成 功 !):history backO:</scripP>": 
oci_close($conn): /关闭 数据 库 


(3) 创建 insertphp 文件 ， 通 过 form 表单 将 员工 数据 提交 到 insert_ok php 文件 中 。 
(4) 获取 form 表单 中 提交 的 数据 ， 通 过 oci bind by _name0 函 数 将 员工 数据 添加 到 指定 的 数据 表 中 ， 其 关 
键 代码 如 下 


<?php 

header ( "Content-type: text/html; charset=utf-8" ); // 设 置 文件 编码 格式 

include("conn/conn.php"); 

if($_POST['Submit]==true || $_POST[id]==true || $_POST[user]—true){ // 判 断 提交 数据 是 否 为 空 
$query = insert into tb_user values(:id, :name, :position, :age, :dates); /定义 添加 语句 
Sresult = oci_parse($conn, $query); // 配 置 Oracle 添加 语句 
oci_bind_by_name(S$result, “id', $_POST[id]); /添加 数据 


oci_bind_by_name($result, :name', $_POST[user]); 
oci_ bind_by_name($result, :position’, $_POST[position]): 
oci_bind_by_name($result, “age', $_POST[age]): 
oci_bind_by_name($result, "dates', date("Y-m-d H:i:s")); 
Smyrow = oci_execute(Sresult); /| 执行 添加 语句 
这 $myrow) 
Print "<script> alert ("数据 添加 成 功 !"):history.back0;</script>"; 
oci_close(Sconn): /关闭 数据 库 
yelse{ 
print "<script> alert (数据 不 能 为 空 !):history.back0;</script>"; 
} 


2> 


国 秘笈 心 法 


心 法 领悟 323: 关闭 Oracle 数据 库 。 
在 Oracle 函数 库 中 ， 应 用 oci_close0 函 数 关 闭 数据 库 ， 如 果 成 功 返回 TRUE， 失 败 则 返回 FALSE， 代 码 如 下 : 


bool oci_close( resource connection ) 
A 态 添加 | 
国 实例 说 明 


在 本 实例 中 应 用 oci_fetch_array0 函 数 获取 Oracle 数据 库 的 查询 结果 ， 并 且 通 过 while 语句 将 查询 结果 作为 
下 拉 列 表 框 的 值 进 行 循环 输出 ， 其 运行 效果 如 图 12.5 所 示 。 


用 用 DA 和 ET 


12.5 下 拉 列 表 值 的 动态 添加 


力 关键 技术 
oci_fetech_array0 函数 ， 从 结果 集中 获取 一 行 作为 关联 数组 或 数字 数组 或 二 者 兼 有 ， 详 解 请 参考 实例 520。 
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四 设计 过 程 

本 实例 所 讲解 的 技术 已 经 在 实例 523 中 应 用 ， 在 本 实例 中 完全 应 用 上 一 实例 的 内 容 ， 有 关 其 创建 过 程 这 里 
不 再 次 述 。 

定义 到 index.php 文件 ， 在 员工 信息 查询 的 forml 表单 中 ， 员 工 ID 下 拉 列 表 框 值 就 是 通过 oci_fetch_ array0 
函数 和 while 语句 动态 添加 的 ， 其 关键 代码 如 下 : 


<form id="form]" name="foml" method="post" action="index.php"> 
<tr> 
<td height="30" align="right" class="STYLE3"> 按 照 ID 搜索 用 户 :</td> 
<td height="30" align="left" class="STYLE3"> 
<sclect name="select"> 
< 
include("conn/conn.php"); 
Squery="select * from tb_user "; 
Sresult=oci parse($conn,$query); 
Sr = oci_execute($result, OCI DEFAULT); 
while($row=oci_fetch_array(SresultOCIL RETURN_NULLS){ 
> 


<option value="<?php echo $row[0]:?>"><?php echo Srow[0]:?></option> 
<?php 
oci_close(Sconn); 
> 


</select></td> 
<ir> 
</form> 


有 关 本 实例 的 其 他 内 容 在 实例 523 中 已 经 介绍 ， 这 里 不 再 歼 述 。 
心 法 领悟 524: 使 用 oci_fetch_array() 函 数 的 注意 事项 。 


(1) 本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 
(2) 使 用 oci_fetch_array0 函 数 并 不 比 使 用 oci_fetch_row0 函 数 慢 ， 而 且 还 能 提供 更 多 的 返回 值 。 


CR ， 
高 级 | 
实例 525 趣味 指数 : | 

用 实例 说 明 


号; 明日 人 管理 系统 


本 Es 


图 12.6 统计 数据 库 中 数据 的 记录 总 数 


力 关键 技术 
本 实例 中 ， 统 计数 据 库 中 数据 的 记录 总 数 应 用 的 是 oci_fetch_all0 函 数 ， 然 后 在 foreach 和 for 语句 的 辅助 之 
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下 完成 数据 库 中 数据 的 循环 输出 。 
oci_fetch allO 函 数 将 获取 的 所 有 数据 存储 到 一 个 数组 中 。 它 从 一 个 结果 中 获取 所 有 的 行 到 一 个 用 户 定 义 的 
数组 ， 返 回 获取 的 行 数 ， 如 出 错 则 返回 FALSE， 其 语法 如 下 : 


int oci_fetch all ( resource statement array &output [, int skip [, int maxrows [, int flags]]] ) 


oci fetch all0 函 数 的 参数 说 明 如 表 12.6 所 示 。 
表 12.6 oci_fetch_all() 函 数 的 参数 说 明 


参数 说 明 

statement 必 选 参数 ， 获 取 的 语句 标识 符 

output 必 选 参数 ， 定 义 存储 数据 的 数组 

skip 可 选 参数 ， 从 结果 中 获取 数据 时 ， 最 开始 忽略 的 行 数 〈 默 认 值 是 0， 即 从 第 一 行 开 始 ) 
maxrows 可 选 参数 ， 要 读 取 的 行 数 ， 从 第 skip 行 开始 (默认 值 是 -1， 即 所 有 行 ) 


可 选 参数 ，flags 参数 可 以 是 下 列 值 的 任意 组 合 : 
OCI FETCHSTATEMENT BY ROW 


flags OCI FETCHSTATEMENT_BY_COLUMN (上 默认 值 ) 
OCL NUM 
OCT ASSOC 
力 设计 过 程 
(1) 新 建 conn 文件 夹 ,编写 conn.php 文件 连接 Oracle 数据 库 , 并 设置 数据 库 的 编码 格式 为 UTF-8。conn.php 
的 代码 如 下 : 
<?php 


/连接 数据 库 名 为 oracle， 用 户 名 是 system， 密 码 是 mrsoft 
/如 果 Oracle 数据 库 服 务 器 与 PHP 程序 处 于 同一 机 器 中 ， 在 连接 时 数据 库 名 称 可 以 省 略 
S$conn=oci connect("system", "mrsoft","oracle", "utf8") or dir(oci_errorO); 
2 
(2) 创建 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 执 行 查询 语句 ， 通 过 oci_fetch_all0 函 数 获取 数据 库 中 总 
的 记录 数 ， 并 且 将 查询 结果 存储 到 $results 数组 中 ， 最 后 通过 foreach 语句 和 for 语句 循环 输出 数组 中 的 数据 ， 其 


关键 代码 如 下 : 
<?php 
include("conn/conn.php"); // 包 含 数据 库 连接 文件 
$stmt = oci_parse($conn, "select * from tb_user"); // 预 置 Oracle 查询 语句 
oci_execute($stmt); // 执 行 查询 语句 
Snrows = oci_fetch_all($stmt, $results): // 获 取 查询 结果 的 记录 数 
ff($nrows > 0) { // 判 断 查询 结果 
> 
<t> 
<?php 
foreach ($results as $key => $val) { /循环 输 出 数据 库 中 字段 的 标题 
> 
<td height="30" align="center" valign="middle" bgcolor="#FFFFFF"><?php echo $key:?></td> 
<2php 
沁 
</tr> 
<?php 
for ($i= 0: $i < $nrows: $it+) { // 根 据 记 录 总 数 执行 for 循环 
> 
<t> 
<?php 
foreach ($results as $data) { // 输 出 数据 库 中 的 数据 
> 
<td align="center" valign="middle" bgcolor="#FFFFFF"><?php echo $data[$i]:?></td> 
<?php sy 
> 
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<td height="35" colspan="5" align="right" bgcolor="#FFFFFF"><span class="STYLE1"><?php echo "总 共有 $nrows 记录 !":?> </td> 
</tr> 


<Iphp 

Jelse{ 

?> 

<tr><td colspan="5" align="center" bgcolor-"#FFFFFF"> 无 数据 <ltd> 
<ltr> 

ee 

oci_close(Sconn); 

?> 


心 法 领悟 525: oci_fetch_all0 函 数 的 应 用 总 结 。 
应 用 oci_fetch_all0 函 数 获取 数据 库 中 总 的 记录 时 ， 在 其 返回 的 数组 中 不 但 包括 数据 表 中 的 数据 而 且 还 包括 
数据 表 字 段 的 名 称 。 因 此 ， 在 应 用 oci_fetch_all0 函 数 循环 输出 数据 表 中 的 数据 时 ， 不 必 单 独 定义 数据 表 字段 的 


实例 526 趣味 指数 : 福 食 三 从 


有 


力 实例 说 明 


如 果 采 用 固定 字段 名 称 的 方法 输出 数据 表 中 的 数据 ， 那 么 一 旦 数据 表 中 的 字段 发 生变 化 ， 再 通过 原来 的 表 
格 输出 数据 表 中 的 数据 时 ， 其 运行 效果 将 如 图 12.7 所 示 ， 页 面 输出 内 容 是 不 完整 的 。 


导致 页 面 不 完整 


pyr 


12.7 采用 固定 字段 名 称 的 方法 输出 数据 表 中 的 数据 


如 果 采 用 动态 读 取 数 据 表 中 的 字段 和 数据 的 方法 就 可 以 避免 图 12.7 所 示 的 问题 ,无 论 字段 发 生 怎样 的 变化 ， 
在 页 面 中 输出 的 数据 都 是 完整 的 ， 不 必 对 页 面 的 设计 进行 重新 调整 ， 其 运行 效果 如 图 12.8 所 示 。 


人 aial 
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图 关键 技术 


在 本 实例 中 ， 首 先 应 用 oci_ num _ fieldsO 函 数 获取 数据 表 中 数据 的 列 数 ， 其 语法 如 下 : 


int oci_num fields( resource statement ) 
该 函数 返回 参数 statement 中 列 的 数目 ， 其 中 参数 statement 为 oci_parse0 函 数 返回 的 标识 符 。 
然后 应 用 oci_field_name0 函 数 动态 获取 数据 表 中 的 字段 信息 ， 其 语法 如 下 : 


string oci_field_name( resource statement. int field ) 


该 函数 返回 与 字段 数字 索引 〈 从 1 开始 ) 相对 应 的 字段 名 。 
最 后 应 用 oci_fetch rowO 函 数 完成 数据 库 中 数据 的 循环 输出 ， 以 数字 作为 数组 的 索引 ， 其 语法 如 下 ; 


array oci_fetch row( resource statement ) 


该 函数 从 和 指定 的 结果 标识 关联 的 结果 集中 获取 一 行 数据 并 作为 数组 返回 , 如 果 没 有 更 多 行 则 返回 FALSE。 


每 个 结果 的 列 存储 在 一 个 数组 的 单元 中 ， 数 字 索 引 从 0 开始 。 


通过 本 实例 中 介绍 的 函数 循环 输出 数据 库 中 的 数据 ， 可 以 避免 因数 据 表 增加 字段 或 者 减少 字段 而 要 重新 设 


计 页 面 的 麻烦 。 
力 设计 过 程 


(1) 新 建 comn 文件 夹 , 编写 conn.php 文件 ,定义 Oracle 数据 库 的 连接 方法 , 设置 数据 库 的 编码 格式 为 UTF-8。 
(2) 新 建 index.php 文件 ， 首 先 包含 数据 库 连 接 文件 ， 然 后 应 用 oci_num_fields0 和 oci_field_name0 函 数 以 
及 for 语句 完成 数据 表 中 字段 名 称 的 输出 。 最 后 应 用 oci_fetch_row0 函 数 和 while 语句 ， 根 据 数据 表 中 字段 的 列 


数 完成 数据 的 循环 输出 ， 其 关键 代码 如 下 : 


<?php 

include("conn/conn.php"): // 包 含 数据 库 连接 文件 
$stmt = oci_parse($conn, "select * from tb_user”); // 定 义 查询 语句 
Oci_execute($stmt); // 预 置 Oracle 语句 
Sncols = oci_num _fields($stmt); /获取 数据 表 字 段 的 列 数 
for ($i= 1: Si<= $ncols: $it+){ /| 执行 for 循环 
S$ficld_name =oci_ficld name($stmt, Si // 获 取 字 段 的 名 称 


echo "<td bgcolor=#FFFFFF' align='center’ >$ficld name</td>"; 


oci_free_statement($stmt); // 释 放 关 联 于 Oracle 语句 或 游标 的 所 有 资源 
> 

</tr> 
<?php 
Squery="select * from tb_user "; /定义 SQL 语句 
S$result=oci_parse($conn.Squery); // 预 置 Oracle 语句 
S$r = oci_execute(S$result, OCI DEFAULT): /执行 查询 语句 
while($row=oci_fetch_row(S$result){ /while 循环 输出 查询 结果 数组 中 的 数据 
?> 

<tr> 
<?php 


for ($i= 0; $i< $ncols: Sit+) { 


// 根 据 字段 的 列 数 输 出 数据 


echo "<td bgcolor=#FFFFFF' align='center >$row[$il</td>"; 


} 


9 
</r> 
<?php 


oci_close($conn): 
> 


和 秘笈 心 法 


// 关 闭 数据 库 


心 法 领悟 526: 盘点 本 实例 应 用 的 函数 。 
oci_field_name() 函 数 返 回 与 字段 数字 索引 (从 1 开始 ) 相对 应 的 字段 名 ， 即 获取 第 一 个 字段 的 名 称 时 ， 应 
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该 使 用 如 下 格式 : 
Sficld name =oci field name($stmt, 1); /获取 字段 的 名 称 
oci_fetch row0 函 数 返 回 数组 ， 数 组 的 数字 索引 从 0 开始 ， 即 获取 oci_fetch row0 函 数 返回 数组 中 的 第 一 个 
元 素 值 的 格式 是 : 
Srow=oci_fetch_row(Sresult); 
Srow[O]; /| 数组 中 的 第 一 个 元 素 
了 7 Te OO | 
实例 527 信息 si 
趣味 指数 : 妇女 娘家 | 


力 实例 说 明 
前 面 讲解 的 都 是 获取 Oracle 数据 库 中 数据 的 方法 ， 在 本 实例 中 将 介绍 如 何 获取 数据 表 中 字段 的 详细 信息 ， 
运行 结果 如 图 12.9 所 示 。 


于 各 和 | 字 入 本 度 


原 Orssks 数据 检 开 


DATES 0 0 ' 0 


图 12.9 获取 数据 表 中 字段 的 详细 信息 


图 关键 技术 


本 实例 是 多 个 函数 的 综合 应 用 ， 其 中 包括 : 

加 ”oci_num fieldsO 函 数 : 获取 结果 列 的 数目 。 
oci_field_name() 函 数 ， 获取 字段 的 名 称 。 
oci_field_precision0) 函 数 : 获取 字段 的 精度 。 
oci_field_scale() 函 数 : 获取 字段 的 范围 。 
oci_field_type0 函 数 : 获取 字段 的 数据 类 型 。 
oci_field_size() 函 数 ， 获取 字段 的 大 小 。 
oci_field_type_raw0 函 数 : 获取 字段 的 原始 Oracle 数据 类 型 。 


图 设计 过 程 
本 实例 综合 运用 Oracle 函数 库 中 操作 数据 表 字 段 的 函数 ， 获 取 数据 表 中 字段 的 各 种 信息 ， 并 且 以 表格 的 形 
式 输出 获取 到 的 数据 ， 其 关键 代码 如 下 : 


<table width="580" border="1" cellpadding="1" cellspacing="1" bordercolor="#FFFFFF" bgcolor="#339999"> 
<tr><td colspan="6" align="center" bgcolor="#FFFFFF">TB_USER2 表 的 字段 信息 </td></tr> 
<tr> 
<td align="center" bgcolor="#FFFFFF"> 字 段 名 称 </td> 
<td align="center" bgcolor="#FFFFFF"> 字 段 精度 </td> 
<td align="center" bgcolor="#FFFFFF"> 字 段 范围 </td> 
<td align="center" bgcolor="#FFFFFF"> 数 据 类 型 </td> 
<td align="center" bgcolor="#FFFFFF"> 字 段 大 小 </td> 
<td align="center" bgcolor="#FFFFFF"> 原 Oracle 数据 类 型 </td> 
<ltr> 
php 
include("conn/conn.php"); 
$stmt = oci_parse($conn, "select * from tb_user"); // 定 义 查询 语句 
oci_execute($stmt); 
$result = oci_num fields($stmt): /统计 字段 的 数目 
for ($i= 1: $i<= Sresult $it+) { 


回回 图 加 加 加 
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S$column name = oci ficld name($stmt, $i): /获取 字段 名 称 
Scolumn _precision = oci_field_precision($stmt, $i); /获取 字段 的 精度 
Scolumn scale =oci_field_scale($stmt. $1); // 获 取 字 有 段 的 范围 
S$column type = oci_field type($stmt, $i); /字段 的 数据 类 型 
Scolumn size = oci_field_size($stmt, $i); /获取 字段 的 大 小 


S$column type_raw = oci_field type_raw($stmt., $i); // 获 取 字 段 的 原始 Oracle 数据 类 型 
Pn 


<u> 
<td alipn='eenter bgeolor-"#FFFFFF"><?php echo Seolumn name :7></td> 


<td align="center" bgcolor="#FFFFFF"><?php echo $column_type :2></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $column_size :?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $column_type_raw ;7></td> 


<lt> 
总 
oci_free_statement($stmt); /释放 资源 
oci_close($conn); /关闭 数据 库 
?> 
</table> 


图 秘笈 心 法 

心 法 领悟 327: 获取 数据 表 中 字段 信息 的 函数 。 

获取 数据 表 中 的 字段 信息 并 不 是 一 项 常用 的 技术 ， 它 只 会 出 现在 一 些 特殊 操作 中 ， 例 如 动态 创建 数据 表 、 
在 网 站 的 后 台 管 理 系统 中 查看 数据 表 的 结构 等 。 其 中 只 有 oci_num fields 0 和 oci_field_name() 函 数 可 能 会 经 常 使 
用 ， 有 关 这 些 函 数 的 详细 讲解 请 参考 PHP 手册 。 


高 级 | 


实例 528 趣味 指数 : 请 廊 育 家 | 


力 实例 说 明 
在 本 实例 中 ， 介 绍 一 种 可 以 远程 修改 Oracle 数据 库 用 户 密码 的 方法 ， 其 运行 效果 如 图 12.10 所 示 。 


用 户 登录 Lcgm 


用 户 名 : 


nf 


图 12.10 ”修改 Oracle 数据 库 用 户 的 密码 


图 关键 技术 


修改 Oracle 数据 库 用 户 的 密码 应 用 的 是 oci password_change0 函 数 ， 其 语法 如 下 : 

bool oci_password_change ( resource connection, string usemame, string old_password, string new_password ) 
oci_password_change0) 函 数 用 于 修改 用 户 usermame 的 密码 。 如 果 成 功 返 回 TRUE， 失 败 则 返回 FALSE。 
oci_password_change() 函 数 的 参数 说 明 如 表 12.7 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 
表 12.7 oci_password_change() 函 数 的 参数 说 明 


参数 说 明 


connection | 必 选 参数 ， 数 据 库 连接 成 功 后 返回 的 连接 标识 符 
usemame | 必 先 参数， 数据库 的 用 户 名 
old password | 必 选 参数 ， 旧 密码 


new password 必 选 参数 ， 新 密码 
图 设计 过 程 
(1) 新 建 数据 库 连接 文件 conn.php， 连 接 用 户 名 为 system， 密 码 为 mrsoft 的 Oracle 数据 库 。 
(2) 新 建 index.php 文件 ,创建 form 表单 ， 将 Oracle 数据 库 的 信息 提交 到 index_ok.php 文件 中 ， 在 该 文件 
中 完成 数据 库 用 户 密码 的 更 新 。 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 提交 的 Oracle 数据 库 用 户 名 的 信息 ， 应 用 oci_password_change0 
函数 更 新 Oracle 数据 库 用 户 的 密码 ， 其 代码 如 下 : 
i "Content-type: text/html; charset=utf-8" ): /设置 文件 编码 格式 
include("conn/conn.php"); // 包 含 数据 库 连接 文件 
if($_POST['user]!="" | $_POST['pass_old]!="" | $_POST['pass new']—$_POST['pass news]){ 
$pass=oci_password_change($conn,$_ POST['user].$_ POST[pass old]$_ POST[pass_ new]); /执行 更 新 操作 
这 Spass 一 tmue 
多 小 window.location href-'index-php';</script>"; 
else 
"<script>alert( 密 码 更 新 失败 ! ); window location href='index.php';</script>"; 
人 / 凑 闭 数据 库 
jelkse 


echo "<script>alert(' 添 加 信息 不 正确 失败 ! ); windowlocation href='index php':</script>"; 
} 


> 


图 秘笈 心 法 
心 法 领悟 528: oci_password_change (0) 函 数 的 第 二 种 语法 格式 。 


oci_password_change () 函 数 的 第 二 种 语法 格式 如 下 : 
edource ci paseword, change ( siring dbname, stiing usernanme, tring old_ password) siiing ew password ) 


该 语法 格式 自 版 本 1.1 (OCI8 扩展 库 版 本 ) 起 可 用 。 


实例 529 


力 实例 说 明 


PHP 的 事务 处 理 机 制 可 以 确保 在 操作 过 程 中 遇 到 意外 《〈 如 突然 断 电 、 计 算 机 死机 等 ) 时 数据 不 丢失 。 在 本 
实例 中 ， 应 用 事务 实现 数据 删除 和 添加 同时 操作 并 且 输 出 操作 执行 后 的 结果 ， 如 图 12.11 所 示 。 


深 加 的 数据 ] 


图 12.11 事务 处 理 机 制 的 应 用 
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图 关键 技术 


在 Oracle 数据 库 中 通过 oci commitO 函 数 提交 未 执行 的 事务 处 理 操作 。oci commit 函数 的 语法 如 下 : 


bool oci_commit( resource connection ) 


oci_commit0 函 数 将 正在 运行 的 事务 中 所 有 未 执行 的 查询 语句 提交 处 理 , 如 果 成 功 返 回 TRUE, 否则 返回 FALSE。 
通过 oci rollbackO 函 数 回 滚 未 提交 的 事务 ， 其 语法 如 下 : 


bool oci_rollback( resource connection ) 


oci_rollback0) 函 数 回 深 Oracle 连接 connection 上 所 有 未 提交 的 语句 , 如 果 成 功 返 回 TRUE, 否则 返回 FALSE。 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 完 成 与 Oracle 数据 库 的 连接 ， 并 且 设置 数据 库 编码 格式 为 UTF-8。 
(2) 新 建 ndex.php 文件 。 首 先 执行 查询 操作 ， 并 且 将 查询 结果 作为 form 表单 元 素 的 初始 值 ， 将 表单 元 素 


中 的 值 提交 到 index_ok.php 文件 中 进行 删除 处 理 。 然 后 再 次 执行 查询 操作 ， 输 出 执行 删除 操作 后 数据 库 中 剩余 
的 数据 ， 其 关键 代码 如 下 : 


<?php 
include("conn/conn.php"); 
Squery="select * from tb_user "; 
Sresult=oci_parse($conn.$query); 
Sr = oci execute($result, OCI DEFAULT); 
while($row=oci_fetch_array($result.OCI RETURN_NULLS){ 
> 
<form id="forml" name="form1" method="post" action="index_ok.php"> 
<tr> 
<td align="center" valign="middle"><span class="STYLE4"> 
<input name="id" type="text" id="id" size="5" value="<?php echo $row[0]:?>" /> 
</span></td> 
<td align="center" valign="middle"><span class="STYLE4"> 
<input name="user" type="text" id="user" size="8" value="<?php echo $row[11:?>" /> 
</span></td> 
<td align="center" valign="middle"><span class="STYLE4"> 
<input name="position" type="text" id="position" size="S" value="<?php echo $row[2]:?>" /> 
</span></td> 
<td align="center" valign="middle"><span class="STYLE4"> 


<input name="age" type="text" id="age" size="10" value="<?php echo $row[3]:?>" /> 
</span></td> 
<td align="center" valign="middle"> 
<input type="submit" name="Submit" value=" 删 除 " /> </td> 
</> 


ee 
(3) 创建 index_ok.php 文件 ， 获 取 form 表单 提交 的 数据 ， 首 先 根据 提交 的 ID 值 执行 数据 的 删除 操作 ， 然 
后 定义 添加 语句 将 表单 中 提交 的 数据 添加 到 指定 的 数据 表 中 。 最 后 应 用 oci_commitO 函 数 通 过 事务 提交 数据 ， 
如 果 提交 执行 失败 ， 则 应 用 oci_rollbackO 函 数 实现 事务 的 回 滚 ， 其 代码 如 下 : 


<2php 
header ( "Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
include("conn/conn.php"); // 包 含 连接 数据 库 文件 
if($_POST['Submit]==true) { 

$query="delete from tb_user where id=".$_POST['id]."; /定义 删除 语句 


Sresult=oci_parse($conn,$query); // 预 置 Oracle 语句 
S$r=oci_execute($result.OCI DEFAULT): /执行 删除 操作 
$query="insert into tb_user (id,name.position.age)values(1000',".$_POST['user].",".$_POST['position].",".$_POST['age].")"; 
Sresult=oci_parse($conn,$query); 
oci_execute($result, OCI DEFAULT): /设置 参数 为 OCI DEFAULT， 停 止 语句 的 自动 提交 
S$committed = oci_commit(Sconn): /应 用 事务 提交 数据 
if(IScommitted) { // 如 果 事 务 执行 失败 
Serror = oci_error($conn): 
echo 事务 执行 失败 : '. $error['message']: 
} 
oci_rollback($conn): /事务 回 滚 
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这 39{ 
echo "<script> alert(' 删 除 成 功 !"); window.location hre 人 index.php':</script>": 
} 
oci_close(Sconn): 
} 


?> 


图 秘笈 心 法 


心 法 领悟 529: 应 用 事务 处 理 机 制 的 注意 事项 。 
(1) 在 应 用 oci_commit0 函 数 之 前 ， 应 该 先 取 消 oci_execute0 函 数 的 自动 提交 功能 ， 否 则 事务 将 不 会 被 执行 。 
(2) 当 关 闭 连接 或 脚本 结束 时 事务 会 自动 回 滚 。 需 要 明确 地 调用 oci_commit() 函 数 来 提交 事务 ， 或 调用 
oci rollbackO 函 数 来 中 止 事务 。 


实例 530 


力 实例 说 明 
在 操作 Oracle 数据 库 时 ， 循 环 输出 数据 库 中 的 数据 多 数 应 用 的 是 Oracle 数据 库 函数 。 在 本 实例 中 ， 介 绍 一 
种 特殊 的 输出 数据 的 方法 一 将 数据 通过 PHP 变量 进行 输出 ， 其 运行 结果 如 图 12.12 所 示 。 


cci_define_by_name 出 数 的 应 用 
用 户 名 密码 地 址 


术科 用 名 3 
吉林 省 闻 日 科 合 认 限 公司 


图 12.12 数据 的 循环 输出 


力 关键 技术 


本 实例 循环 输出 数据 库 中 的 数据 应 用 的 是 oci_define_ by _name0 函 数 ， 将 PHP 变量 值 与 SQL 查询 语句 返 
的 列 进行 绑 定 ， 从 而 直接 通过 PHP 变量 输出 数据 库 中 的 数据 。 

oci_define by_name() 函 数 将 PHP 变量 与 select 语句 中 返回 的 列 进行 绑 定 ， 如 果 定 义 的 变量 不 存在 于 select 
语句 中 ， 则 并 没有 错误 信息 输出 。 该 函数 的 语法 如 下 : 


B60l Oe define by iane ( Tesoroe itement tiing eol ae mixed varable Lipe]) 
oci_define by_name(0) 函 数 的 参数 说 明 如 表 12.8 所 示 。 


表 12.8 oci_define_by_name() 函 数 的 参数 说 明 
参 。 数 说 明 
statement | 必 选 参数 ， 获 取 的 语句 标识 符 
column name | 必 选 参数 ， 指 定 的 字段 名 ， 必 须 大 写 


variable 必 选 参数 ， 输 出 的 变量 


oci_fetchO 函 数 〈 对 于 select 语句 ) 获取 结果 中 的 下 一 行 到 内 部 结果 缓冲 区 。 如 果 成 功 则 返回 TRUE， 失 败 
则 返回 FALSE， 其 语法 如 下 : 


回 
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bool oci fetch( resouree statement ) 
在 PHP 5.0.0 之 前 的 版 本 必须 使 用 ocifetch0 蔡 代 本 函数 。ocifetch0 函 数 名 仍然 可 用 ， 为 向 下 兼容 作为 
oci_fetch0 的 别名 ， 但 不 推荐 使 用 。 
图 设计 过 程 
(1) 新 建 conn.php 文件 ， 连 接 Oracle 数据 库 ， 指 定数 据 库 编码 格式 为 UTF-8， 其 代码 如 下 : 
/机 娄 所 库 名 为 oracle， 用 户 名 是 system， 密 码 是 mrsoft 
// 如 果 Oracle 数据 库 服务 器 与 PHP 程序 处 于 同一 机 器 中 ， 在 连接 时 数据 库 名 称 可 以 省 略 
Seonmroci comeell gm nmol voracle", "utf8") or dir(oci errorO): 
(2) 新 建 index.php 文件 ， 通 过 PHP 变量 完成 数据 的 循环 输出 。 首 先 包含 数据 库 连接 文件 ， 然 后 定义 SQL 
语句 ， 通 过 oci_define by_name0 函 数 将 SQL 语句 中 查询 出 的 字段 名 称 与 指定 的 变量 进行 绑 定 。 最 后 执行 查询 


操作 ， 通 过 while 语句 循环 输出 查询 结果 ， 其 关键 代码 如 下 : 
<?php 


include("conn/conn.php"); // 包 含 数据 库 连 接 文件 
$query="select name, position, age from tb_user "; // 定 义 SQL 语句 
$result=oci_parse($conn,$query); // 预 置 Oracle 语句 
oci_define_ by_name($result "NAME", Sname); /将 字段 name 与 变量 $name 绑 定 


oci_define_by_name($result, "POSITION", $position); 
oci_define_ by_name($result "AGE", $age); 
oci_execute($result); /| 执行 查询 操作 
while (oci_fetch(S$result)) { // 循 环 输出 查询 结果 
?> 
<tr> 
<td align="center" valign="middle">&nbsp;</td> 
<td align="center" valign="middle"><span class="STYLE6"><?php echo $name:?></span></td> 
<td align="center" valign="middle"><span class="STYLE6"><?php echo Sposition:?></span></td> 
<td align="center" valign="middle"><span class="STYLE6"><?php echo $age:?></span></td> 
<ltr> 


a 
oci_free_statement($result); /| 释放 空间 
oci_close($conn); /关闭 数据 库 
?> 
国 秘笈 心 法 


心 法 领悟 330: 应 用 oci_define by_name0 函 数 的 注意 事项 。 
(1) Oracle 使 用 大 写字 母 的 列 名 ， 而 用 户 在 select 中 可 以 用 小 写字 母 。 
(2) 如 果 需 要 定义 一 个 抽象 数据 类 型 (LOBIROWID/BFILE) ， 必 须 先 用 oci_new_descriptor0 函 数 分 配 空间 。 


12.3 Oracle 数据 库 应 用 


前 面 只 是 讲解 连接 Oracle 数据 库 的 方法 以 及 一 些 简单 的 操作 ， 在 本 节 中 将 Oracle 数据 库 应 用 到 实际 的 程序 
开发 中 。 


实例 531 起 味 指 数 二 商 页 
实例 说 明 


本 实例 实现 一 个 管理 员 的 注册 功能 ， 应 用 ADODB 连接 、 操 作 Oracle 数据 库 ， 将 注册 信息 添加 到 指定 的 
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Oracle 数据 表 中 ， 其 运行 结果 如 图 12.13 所 示 。 


FANXING i 设 首 页 1 加 7 中 这 


图 12.13 管理 员 注册 


图 关键 技术 


有 关 ADODB 连接 、 操 作 Oracle 数据 库 的 方法 可 以 参考 实例 521 和 实例 322， 这 里 不 再 袭 述 。 
本 实例 在 完成 管理 员 注册 信息 的 提交 时 ， 应 用 GD2 函数 生成 一 个 数字 验证 码 防 止 数 据 的 重复 提交 。 其 中 验 
证 码 生 成 方法 如 ValidatorCode.php 文件 所 示 : 


< 

人 

srand((double) microtime() * 1000000); // 定 义 随机 数 种 子 
S$im = imagecreate(65, 25); // 创 建 画布 
imagefill($im, 0, 0, imagecolorallocate($im, 200, 200, 200)): /定义 画布 背景 
SvalidatorCode =$_GET['code']: // 获 取 验 证 码 的 值 
// 在 画布 中 输出 验证 码 的 值 


imagestring($im, 8, 9, 2, substr($validatorCode. 0, 1), imagecolorallocate($im, 0. rand(0, 255). rand(0. 255))): 
imagestring($im, 8, 22, 4. substr($validatorCode, 1, 1), imagecolorallocate($im, rand(0, 255), 0, rand(0. 255))); 
imagestring($im, 8, 36. 6, substr($validatorCode. 2, 1), imagecolorallocate($im, rand(0, 255), rand(0, 255). 0)); 
imagestring($im, 8, 48, 8, substr($validatorCode, 3, 1), imagecolorallocate($im, 0, rand(0, 255), rand(0, 255))); 
// 添 加 干扰 线 
for ($i= 0; $i< 200; $i++) { 

imagesetpixel($im, rand() % 70, rand() % 30, imagecolorallocate($im, rand(0, 255), rand(0. 255), rand(0. 255))); 


imagepng($im); // 生 成 png 图 像 
imagedestroy(); // 销 毁 图 像 


图 设计 过 程 
(1) 创建 conn 文件 夹 , 编写 conn.php 文件 , 载 入 adodb.iniphp 文件 。 实现 与 Oracle 数据 库 服务 器 中 Oracle 
数据 库 的 连接 ， 用 户 名 是 system， 口 令 (密码 ) 是 mrsoft， 其 代码 如 下 : 
es // 载 入 ADODB 
Sconn = ADONewConnection('oci8); /建立 一 个 Oracle 连接 
Sconn->Connect("oracle", "system", "mrsoft"); 
?> 
(2) 创建 ndex.php 文件 。 首 先 通过 <scrip 人 标签 载 入 js 脚本 文件 ， 然 后 创建 form 表单 ， 将 管理 员 注 册 信 
息 提 交 到 index_ok.php 文件 中 ， 同 时 定义 onSubmit 事件 调用 chkinput0 方 法 对 表单 中 元 素 值 进行 验证 。 最 后 ， 
创建 JavaScript 脚本 ， 定 义 方法 完成 验证 码 的 输出 和 刷新 操作 ， 其 关键 代码 如 下 : 


<script language="iavascript" sre="js/check.js"></script> 
<form id="forml" name="form1" method="post" onSubmit="retum chkinput(this)" action="index_ok.php"> 
<table width="480" border—="0" align="center”" cellpadding="0" cellspacing-"0"> 
<t> 
<td width="87" align="right"> 管 理 员 : </td> 
<td width="380" align="left"><input name="namer type="text' id="name" size="30" /></td> 
</t> 
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<t> 
<td align="right"> 验 证 码 : </td> 
<td align="left"> 
<input name="check_code" type="text" class="input" id="check_code" size="10" /> 
<input type="hidden" name="defValidatorCode" value="" /> 
<script language="javascript"> 
var num1=Math.round(Math.random()*10000000); 
varnum=numl .toString().substr(0,4); 
document write("<img name=codeimg sre="ValidatorCode php?code="+num+">"); 
forml.defValidatorCode.value=num:; 
function reCode(){ 
var numl=Math.round(Math.random()*10000000); 
var num=numl .toString().substr(0,4); 
document.codeimg.sre="ValidatorCode.php?code="+num: 
form!l .defValidatorCode.value=num; 
3 
</script> 
<a href="javascript:reCode0" class="al"> 看 不 清 </a> 
<itd> 


</tr> 
</table> 
<form> 


(3) 创建 index_ok.php 文件 ， 将 表单 中 提交 的 数据 添加 到 指定 的 数据 表 中 。 在 处 理 密码 时 应 用 MD5 对 密 
码 进 行 加 密 ， 由 于 页 面 中 的 编码 格式 是 UTF-8， 而 Oracle 数据 库 中 使 用 的 是 GB2312， 为 了 避免 数据 输出 时 出 
现 乱码 ， 在 执行 添加 操作 之 前 ， 应 用 iconv0 函 数 将 所 有 提交 的 数据 转换 为 GB2312 编码 ， 其 代码 如 下 : 


<?php 
header ("Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
include("conn/conn.php"); 
if($_POST['name']!="" &é& $ Sle "){ 
$sql="insert into tb admin(id.name.pas: 
values(tb_adminid.nextval," iconv(" i Ca POST[name"]).",".mdS(iconv("utf-8","gb2312",$_POST['passD).™,".date("Y-m-d").")"; 
Srst = $conn->execute ( $sql ) or die (‘error: '. $conn->errorMsg 0 ); 
这 Srsbf 
echo "<script>alert( 管 理 员 添加 成 功 ! '):window location href-index.php?conn_id=1':</script>": 
jelse{ 
echo "<script>alert( 管 理 员 添加 失败 ! ):windwo location href='index.php'</script>"; 
} 


Jelse{ 

a "<script>alert(' 请 输入 管理 员 信 息 ! "):windwo location href="index.php'</script>"; 
} 

by- 


(4) 创建 ValidatorCode.php 文件 ， 定 义 验 证 码 的 实现 方法 ， 详 细 内 容 请 参考 关键 技术 。 
(5) 创建 js 脚本 文件 夹 ， 编 写 check.js 脚本 文件 ， 定 义 chkinput() 方 法 对 表单 中 的 元 素 值 进行 验证 。 


国 秘笈 心 法 


心 法 领悟 531: Oracle 数据 库 中 insert 添加 语句 的 编写 。 
在 创建 数据 表 时 ， 指 定 ID 字段 为 表 的 主键 ， 通 过 序列 完成 主键 ID 值 的 添加 ， 在 本 实例 中 序列 为 
tb_adminid.nextval。 


实例 532 由 朗朗 友信 


国 实例 说 明 


下 面 讲解 Oracle 数据 库 中 管理 员 登 录 功 能 的 实现 , 将 详细 讲解 如 何在 Oracle 数据 库 中 完成 用 户 名 和 密码 的 
验证 操作 ， 本 实例 的 运行 结果 如 图 12.14 所 示 。 
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图 12.14 管理 员 登 录 


力 关键 技术 


本 实例 同样 应 用 ADODB 连接 、 操 作 Oracle 数据 库 ， 在 判断 管理 员 名 称 和 密码 时 ， 应 用 GetArray0 函 数 返 
回 查询 结果 集 数组 ， 应 用 countO 函 数 统计 数组 中 的 元 素 个 数 ， 完 成 对 登录 管理 员 的 判断 。 
GetArray([Snumber_of rows]) 函 数 返回 从 当前 指针 指向 的 记录 开始 , 到 $number_of rows- !1 行 的 全 部 记录 的 
数组 。 
参数 Snumber of rows 表示 指定 的 记录 行 。 如 果 没 有 给 出 ， 则 一 直到 EOF 才 停止 。 
count0 函 数 返 回 数组 中 的 单元 数目 ， 用 来 计算 数组 中 值 的 个 数 ， 其 语法 如 下 : 
int count ( mixed array [, int mode]) 
参数 说 明 : 
amray: 必 选 参数 ， 指 输入 的 数组 。 
mode: 可 选 参数 ，COUNT RECURSIVE (或 1) 。 如 选中 此 参数 ， 本 函数 将 递归 地 对 数组 计数 ， 对 计算 多 
维 数组 的 所 有 单元 尤其 有 用 。 此 参数 的 默认 值 是 0。 
力 设计 过 程 
(1) 创建 comn 文件 夹 ， 编 写 conn.php 文件 ， 实 现 与 Oracle 数据 库 的 连接 。 
(2) 创建 index.php 文件 ， 添 加 form 表单 ， 将 管理 员 登 录 信 息 提交 到 index_ok.php 文件 中 。 
(3) 创建 index_ok.php 文件 ， 根 据 表单 中 提交 的 管理 员 名 称 和 密码 执行 查询 语句 ， 如 果 返 回 值 大 于 0， 则 
说 明 名 称 和 密码 正确 ， 将 跳 转 到 main.php 页 面 ; 否则 将 弹出 提示 信息 并 跳 转 到 index.php 页 面 ， 其 代码 如 下 : 
<? 
Ee ("Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
include("conn/conn.php"); 
if($_POST['user]!="" && $_POST[pass]!="){ 
S$sql="select * from tb_admin where name=" iconv("utf-8"."gb2312",$_POST['user])." and pass=" .md$(iconv("utf-8","gb2312",$_POST['pass]))."™" 
Srst = $conn->execute ( $sql ) or die ( 'error: '. $conn->errorMsg 0 ): 
TT) { 
ee echo "<script>alert(' 管 理 员 登 录 成 功 ! '):window.location.href='main.php':</script>"; 
echo "<script>alert(' 管 理 员 登录 失败 ! "):window.location href='index.php'</script>"; 
} 
ras "<seript>alert( 请 输入 管理 员 信息 ! window ,location href-"index.php'</script>"; 


?> 
(4) 创建 main.php 文件 ， 定 义 管理 员 登 录 成 功 后 展示 的 页 面 。 
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图 秘笈 心 法 


心 法 领悟 532: 编码 格式 转换 的 必要 性 。 

在 创建 的 Oracle 数据 库 中 ， 数 据 的 编码 格式 是 GB2312， 而 程序 页 面 中 的 编码 格式 是 UTF-8， 所 以 在 执行 
select 查询 语句 时 ， 在 where 条 件 中 ,必须 应 用 iconv0 函 数 对 表单 中 提交 的 用 户 名 和 密码 进行 编码 转换 ， 使 其 与 
数据 库 中 存储 的 数据 编码 统一 ， 这 样 才 可 以 进行 比较 。 否 则 由 于 数据 的 编码 格式 不 同 ， 无 论 输 入 的 用 户 名 和 密 
码 是 否 正确 都 不 能 成 功 登录 。 唯 一 一 种 对 数据 编码 格式 没有 限制 的 情况 就 是 数据 中 不 包含 中 文字 符 串 。 


高 级 
趣味 指数 走 宙 二 从 


图 实例 说 明 


本 实例 在 实现 管理 员 登 录 功 能 的 基础 上 ， 增 加 对 管理 员 数 据 的 更 新 和 删除 功能 。 可 以 对 管理 员 的 名 称 、 密 
码 和 注册 时 间 进 行 更 新 操作 ， 同 时 也 可 以 删除 指定 的 管理 员 数 据 ， 其 运行 结果 如 图 12.15 所 示 。 


管理 本 
REN LILZTIYUAN GUAN LU XI TONC 


肋 称 ”| ”刻本 ”| 注 基本 间 | 操作 
[EE ECDIS | 


12.15 “管理 员 数 据 的 更 新 和 删除 


力 关键 技术 


这 里 仍 应 用 ADODB 连接 、 操 作 Oracle 数据 库 。 以 数据 表 中 数据 的 ID 为 条 件 ， 执 行 update 更 新 和 delete 
删除 语句 。 

在 本 实例 中 ， 管 理 员 登录 成 功 后 ， 应 用 SESSION 会 话机 制 将 登录 的 管理 员 名 称 存储 到 SESSION 变量 中 ， 
通过 这 个 SESSION 来 控制 用 户 的 权限 ， 如 果 是 管理 员 则 可 以 执行 管理 员 数 据 的 更 新 和 删除 操作 ， 否 则 将 给 出 提 
示 信 息 ， 并 跳 转 到 管理 员 登 录 页 面 ， 其 关键 代码 如 下 : 

<php 


session_start(); // 初 始 化 SESSION 变量 
header ( "Content-type: text/html; charset=utf-8" ); /设置 文件 编码 格式 
if($_SESSION['name]!=""){ /判断 管 理 员 的 名 称 是 否 为 空 


include("conn/conn .php"): // 包 含 数据 库 连 接 文件 
这 $_POST['Submit2] 一 "删除 "){ 
$sql="delete from tb admin where id=".$ POST[conn idl"": 
Srst = $conn->execute ( $sql ) or die (‘error: ，. $conn->errorMsg 0 ); 
ifSrsb{ 
echo "<script>alert( 管 理 员 删 除 成 功 ! ");:window location hre 人 ~’main.php':</script>"; 
Jelse{ 
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echo "<script>alert( 管 理 员 删除 失败 ! '):windwo location href=main.php'</script>"; 
} 
} 
if$_POST['Submit] 一 "更 新 "){ 
$sql="update tb_admin set name=".iconv("utf-8"."gb2312".$ POST[mame]).".pass= "mdsficonv("utf-8""gb2312".$_POST[pass])." 
dates=".$ POST[T'dates]." where id=".$ POSTTconn id]"": 
S$rst = $conn->execute ( $sql ) or die ('emror: '. $conn->errorMsg 0 ): 
if(Srsd{ 
echo "<script>alert( 管 理 员 更 新 成 功 ! ):window location .href='main php';</script>"; 
jslsef 
echo "<script>alert( 管 理 员 更 新 失败 ! ):windwo location href- main php'</script>": 
n 
} 
jelsef 
echo "<script>alert(' 您 不 具备 管理 员 权限 ! ):windwolocation href-index .php'</script>": 
入 
其 中 ， 在 管理 员 登 录 的 处 理 页 index_ok.php 中 ， 首 先 初始 化 SESSION 变量 。 在 通过 登录 验证 后 ， 将 登录 让 
户 名 存储 到 SESSION 变量 中 。 
在 数据 的 更 新 和 删除 处 理 页 中 ， 首 先 初 始 化 SESSION 变量 ， 然 后 通过 判断 SESSION 变量 的 值 是 否 为 空 来 


决定 当前 用 户 是 否 具有 管理 员 的 权限 。 
图 设计 过 程 

(1) 创建 comn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 Oracle 数据 库 的 连接 。 

(2) 创建 index.php 文件 ， 添 加 form 表单 ， 将 管理 员 登 录 的 数据 提交 到 index_ok.php 文件 中 。 

(3) 创建 index_ok.php 文件 ， 完 成 登录 用 户 的 验证 操作 。 首 先 初始 化 SESSION 变量 ， 包 含 数据 库 连 接 文 
件 。 然 后 执行 select 查询 语句 , 根据 GetArray0 函 数 返 回 的 数组 元 素 个 数 判 断 登录 用 户 的 用 户 名 和 密码 是 否 正 确 ， 
如 果 正 确 ， 则 将 用 户 名 赋 给 SESSION 变量 , 并 且 跳 转 到 main.php 页 面 ; 否则 ,给 出 提示 信息 ， 跳 转 到 index.php 
页 面 。 


(4) 创建 main.php 文件 ， 在 form 表单 中 循环 输出 管理 员 数 据 ， 并 且 创建 管理 员 数 据 的 更 新 和 删除 按钮 ， 
将 数据 提交 到 main_ok.php 文件 完成 更 新 和 删除 操作 ， 其 关键 代码 如 下 : 


<?php 


include_once ‘conn/conn.php'; // 载 入 数据 库 连 接 文件 
$sqlstr = 'select * from tb_admin '; //SQL 查询 语句 

S$rst = $conn->execute ( $sqlstr ) or die ( 'error: '. $conn->errorMsg () ); // 执 行 查 询 语句 

while (! $rst->EOF ) { //while 语句 循环 输出 结果 


?> 
<form id="form<?php echo $rst->fields [0]; ?>" name="form<?php echo $rst->fields [0]; ?>" method="post" action="main_ok php"> 
<t> 
<td align="center" bgcolor="#FFFFFF"> 
<input name="name" type="text" id="name" size="15" value="<?php echo iconv("gb2312","utf-8",$rst->fields 1'1"]):?>" /></td> 
<td align="center" bgcolor="#FFFFFF"> 
<input name="pass" type="password" id="pass" value="<?php echo iconv("gb2312","utf-8",$rst->fields [2):?>" size="15" /></td> 
<td align="center" bgcolor="#FFFFFF"> 
<input name="dates" type="text" id="dates" size="15" value="<?php echo iconv("gb2312","utf-8",$rst->fields [3]):?>" /></td> 
<td align="center" bgcolor="#FFFFFF"> 
<input type="hidden" name="conn id" value="<?php echo $rst->fields [0]: ?>" /> 
<input type="submit" name="Submit" value=" 更 新 " />&nbsp:&nbsp: 
<input type="submit" name="Submit2" value=" 删 除 " /> 
<ltd> 
<t> 
</form> 
< 
Srst->movenext (); // 指 针 下 移 
S$rst->close |: /关闭 连接 
全 >close 0: 


5 创建 main_ok.php 文件 ， 完 成 管理 员 数 据 的 更 新 或 者 删除 操作 。 首 先 初始 化 SESSION 变量 ， 通 过 
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SESSION 变量 判断 当前 用 户 是 否 具有 操作 权限 ， 如 果 有 权限 ， 则 可 以 根据 按钮 的 值 执行 更 新 或 者 删除 操作 ， 否 
则 将 给 出 提示 信息 ， 并 跳 转 到 管理 员 登 录 页 面 ， 其 代码 如 下 : 
<?php 


session_start0: 
header ( "Content-type: text/html; charset=utf-8" ); // 设 置 文 件 编码 格式 
这 $ SESSION['namel!="){ 
include("conn/conn.php"); 
isS_POST[Submit2] 一 "删除 "){ 
$sql="delete from tb_admin where id=".$ POST[conn id]"": 
Srst = $conn->execute ( $sql ) or die (‘error: '. $conn->errorMsg () ); 
ifSrsbf 

echo "<script>alert( 管 理 员 删 除 成 功 ! ):window ,location href="main.php';</script>"; 
Jelse{ 

echo "<script>alert( 管 理 员 删除 失败 ! ):windwo location_ href='main.php'</script>"; 
} 
} 
这 $_ POST[Submit] 一 "更 新 "){ 
$sql="update tb_admin set 
name=" iconv("utf-8", "gb2312",$_POST[name]).".pass=" :mdsS(iconv("ut-S","gb2312",S_POST['pass']).",dates=".$_POST[ dates']." where 
id="$ POST[conn id]"" 
人 
Srsb{ 

echo "<script>alert(' 管 理 员 更 新 成 功 ! ):window.location hre 人 main.php':</script>": 
yelse{ 

echo "<script>alert( 管 理 员 更 新 失败 ! );:windwo.location href="main.php'</script>"; 
jelse 


{ 
echo "<script>alert( 您 不 具备 管理 员 权限 1 );:windwo.location.href='index.php'</script>"; 
} 
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图 秘笈 心 法 

心 法 领悟 533: SESSION 变量 的 应 用 。 

通过 SESSION 变量 的 值 来 判断 当前 用 户 的 权限 是 非常 实用 的 方法 , 其 原理 是 : 在 会 员 或 者 管理 员 登 录 成 功 
后 , 将 登录 的 名 称 或 者 一 个 指定 的 值 赋 给 SESSION 变量 , 由 于 SESSION 变量 可 以 实现 在 不 同 页 面 之 间 的 传递 ， 
所 以 可 以 在 具有 访问 权限 限制 的 页 面 中 判断 这 个 SESSION 变量 的 值 ， 如 果 变 量 值 为 真 ， 则 说 明 这 个 用 户 具有 访 
问 权限 ， 否 则 说 明 当 前 用 户 不 具备 访问 权限 。 


A Oracle 数据 的 分 页 显示 
实例 534 趣味 指教 : 二 真相 从 | 


力 实例 说 明 


在 本 实例 中 ， 同 样 应 用 ADODB 连接 、 操 作 Oracle 数据 库 ， 其 不 同 之 处 是 将 连接 、 操 作 数 据 库 的 方法 封装 
到 类 中 ， 同 时 将 数据 库 中 数据 的 分 页 方法 也 封装 到 类 中 ， 还 有 通过 Smarty 模板 完成 页 面 的 动静 分 离 。 本 实例 完 
成 数据 库 中 员工 信息 的 分 页 输出 ， 其 运行 结果 如 图 12.16 所 示 。 


兴 采 蚤 工 # 全 每 页 号 示 3 名 竺 3 责 共 3 页 首页 上 一 页 下 一 页 尾 页 


图 12.16 Smarty+ADODB 完成 Oracle 数据 的 分 页 显示 
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图 关键 技术 


本 实例 的 关键 是 应 用 面向 对 象 技术 ， 将 Oracle 数据 库 的 连接 、 操 作 以 及 分 页 方法 都 封装 到 类 中 ， 同 时 还 包 
括 Smarty 模板 的 配置 方法 。 应 用 类 的 实例 化 返回 的 对 象 调用 类 中 方法 ， 完 成 与 Oracle 数据 库 的 连接 、 操 作 和 分 


页 ， 最 终 通过 Smarty 模板 完成 页 面 的 动静 分 离 。 


(1) Oracle 数据 库 连 接 类 ConnDB， 不 但 可 以 连接 Oracle 数据 库 ， 还 可 以 连接 MySQL、SQL Server 和 
Access 数据 库 。 该 类 存储 于 system\system.smarty.inc.php 文件 中 ， 其 内 容 如 下 : 


class ConnDB{ 

var $dbtype; 

var $host; 

Var $user; 

var Spwd; 

var $dbname; 

var $debug; 

Var $conn; 

function ConnDB($dbtype. $host, $user, S$pwd, $dbname, $debug=false){ 
Sthis->dbtype=$dbtype; 
Sthis->host=$host; 
Sthis->user=$user; 
Sthis->pwd=$pwd: 
Sthis->dbname=$dbname; 
Sthis->debug=$debug; 


a GetConnIdO{ 
require("./adodbS/adodb.ine.php"); 
if($this->dbtype—"oci8" || $this->dbtype—"mysql" || $this->dbtype—"mssql"){ 
if($this->dbtype—"mysql"){ 
Sthis->conn=NewADOConnection("mysql"); 
jelse if($this->dbtype—"mssql"){ 
S$this->conn=NewADOConnection("mssql"); 


Sthis->conn->Connect($this->host. Sthis->user,$this->pwd.$this->dbname); 


jelsef 
Sthis->conn = ADONewConnection("oci8"); 
Sthis->conn->Connect($this->dbname,$this->user,$this->pwd): 


} 

}elscif($this->dbtype—"access"){ 
Sthis->conn=NewADOConnection("access"); 
Sthis->conn->Connect("Driver={Microsoft Access Driver 

(*.mdb)}:Dbq=".$this->dbname.":Uid=".$this->user.";Pwd=".$this->pwd.";"); 

} 


Sthis->conn->Execute("set names utf8"); 
if($this->dbtype—"mysql") 
S$this->conn->debug=$this->debug; 

return $this->conn: 

上 

funetion CloseConnIdO{ 
Sthis->conn->Disconnect(): 

} 

} 


/构造 方法 ， 为 成 员 变量 赋值 


/实现 与 不 同 数据 库 的 连接 并 返回 连接 对 象 
// 调 用 ADODB 类 库 文件 

// 判 断 成员 变量 传递 的 数据 库 类 型 

1/ 判断 如 果 是 MySQL 数据 库 

/执行 与 MySQL 数据 库 的 连接 
/数据 库 连接 的 用 户 、 密 码 


// 建 立 一 个 Oracle 连接 


/判断 如 果 使 用 的 是 Access 数据 库 


/| 执行 连接 Aceess 数据 库 
/设置 数据 库 的 编码 格式 


// 返 回 连接 对 象 


// 定 义 关闭 数据 库 的 方法 
1/ 执行 关闭 的 操作 


(2) 数据 库 操作 类 AdminDB， 执 行 对 Oracle 数据 库 的 操作 语句 ， 如 果 是 select 语句 ， 成 功 则 返回 结果 集 
数组 ， 否 则 返回 FALSE; 如 果 是 update、insert 或 者 delete 语句 ， 成 功 则 返回 TRUE， 和 否则 返回 FALSE。 该 类 


存储 于 system\system.smarty.inc.php 文件 中 ， 其 内 容 如 下 : 


class AdminDB{ 
function ExecSQL($sqlstr,Sconn){ // 定 义 方法 ， 参 数 为 SQL 语句 和 连接 数据 库 返回 的 对 象 

$sqltype=strtolower(substr(trim($sqlstr).0,6)); // 截 取 SQL 中 的 前 6 个 字符 串 ， 并 转换 成 小 写 

Srs=$conn->Execute($sqlstr): // 执 行 SQL 语句 

if($sqltype—"select"){ // 判 断 如 果 SQL 语句 的 类 型 为 select 
Sarray=$rs->GetRows(); /| 执行 该 语句 ， 获 取 查 询 结 果 
if(count($array)—0 || $rs—false) // 判 断 语 句 是 否 执 行 成 功 

rctum false; // 如 果 查 询 结果 为 0， 或 者 执行 失败 ， 则 返回 FALSE 

clse 
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Teturn $array; // 否 则 返回 查询 结果 的 数组 
Yelscif ($sqltype—"update" | $sqltype—"insert" | $sqltype—"delete"){ 
// 判 断 如 果 SQL 语句 类 型 不 为 select， 则 执行 如 下 操作 
这 Srs) 
Tetum true; // 执 行 成 功 返 回 TRUE 


else 
return false; /否则 返回 FALSE 


} 
(3) 分 页 类 SepPage， 定 义 两 个 方法 ShowDate0 和 ShowPage0 完 成 数据 的 分 页 输出 。 该 类 存储 于 system\ 
system.smarty.inc.php 文件 中 ， 代 码 请 参考 本 书 光盘 。 
(4) Smarty 模板 的 配置 类 SmartyProject， 完 成 Smarty 应 用 的 配置 操作 ， 指 定 模板 页 存储 位 置 ， 指 定编 译 
文件 存储 位 置 。 该 类 存储 于 system\system.smarty.inc.php 文件 中 ， 其 内 容 如 下 : 
require("../Smarty/Smarty.class.php"); // 调 用 Smarty 文件 
/定义 类 ， 继 承 Smarty 父 类 
/定义 方法 ， 配 置 Smarty 模板 
// 指 定 模板 文件 存储 在 根 目录 下 
// 指 定编 译文 件 存 储 位 置 


i 


图 设计 过 程 

(1) 创建 system 文件 夹 。 首 先 定义 system.smarty.inc.php 文件 ， 封 装 Oracle 数据 库 的 连接 和 操作 方法 ， 以 
及 Smarty 的 配置 方法 。 然 后 定义 system.ine.php 文件 ， 对 数据 库 的 连接 和 操作 类 以 及 Smarty 配置 类 进行 实例 化 ， 
并 返回 连接 对 象 。 最 后 创建 Smarty 文件 夹 ， 定 义 Smarty 的 编译 文件 、 配 置 文件 和 缓存 文件 的 存储 目录 。 

(2) 创建 ndex.php 文件 。 首 先 包含 类 的 实例 化 文件 ， 然 后 应 用 Smarty 生成 一 个 注册 函数 ， 实 现 对 数据 库 
中 数据 的 编码 格式 转换 ， 接 着 调用 分 页 类 中 的 方法 完成 数据 的 分 页 输出 ， 并 将 返回 的 结果 存储 到 模板 变量 中 ， 
最 后 指定 模板 页 ， 其 代码 如 下 : 


<php 
require_once("system/system.ine.php"); // 包 含 配 置 文件 
function unHtml($params) { // 创 建 模板 函数 
extract($params); 1/ 读 取 数据 

Sstr=iconv("gb2312","utf-8", $text); 

return $str // 返 回 截取 结果 
} 
S$smarty->register_function("Util", "unHtml"): // 注 册 模 板 函数 
S$arr=$seppage->ShowDate("select * from tb_user ",$conn,3,$_GET["page"]): // 调 用 分 页 类 ， 实 现 分 页 功能 
这 !$arD{ 

S$smarty->assign("isbbs","F"): 


jelse{ 
S$smarty->assign("isbbs","T"): 

$smarty->assign("showpage",$seppage->ShowPage(" 员 工 "." 名 ".","a1")); // 定 义 输出 分 页 数据 的 模板 变量 showpage 
S$smarty->assign("arr", $arr); 

} 


$smarty->assign('title','Smartyt+Adodb 完成 ORACL 数据 库 中 数据 的 分 页 显示 '); 
S$smarty->display("index.html"); 
2> 


(3) 创建 index.html 模板 页 ， 应 用 section 语句 循环 输出 数据 库 中 的 数据 ， 并 且 应 用 注册 模板 函数 对 数据 的 
编码 格式 进行 转换 ， 同 时 输出 模板 变量 中 存储 的 分 页 超 链接 ， 其 关键 代码 如 下 : 


{if $isbbs—"T"} 
{section name=arrid loop=$arr} 
<tr> 
<td align="center" bgcolor="#FFFFFF">{$an[arrid].0}</td> 
<td align="center" bgcolor="#FFFFFF">{Util text=$arr[amrid].1}</td> 
<td align="center" bgcolor="#FFFFFF">{Util text=$arr[amrid].2}</td> 
<td align="center" bgcolor="#FFFFFF">{Util text=$ar[amrid].3}</td> 
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<td align="center" bgcolor="#FFFFFF">{Util text=$arr[amrid].4}</td> 


图 秘笈 心 法 


心 法 领悟 534: ADODB 类 库 和 Smarty 模板 。 

有 关 ADODB 类 库 的 具体 应 用 将 在 第 13 章 中 进行 详细 讲解 ， 而 Smarty 模板 的 应 用 可 以 参考 本 书 第 14 章 。 
在 本 实例 中 , 封装 数据 库 连接 、 操 作 类 、 分 页 类 和 Smarty 模板 的 配置 类 是 一 个 非常 不 错 的 方法 , 推荐 读者 使 用 ， 
并 且 可 以 对 它 进行 不 断 地 完善 。 例 如 ， 扩 展 其 支持 更 多 的 数据 库 、 更 改 分 页 类 的 方法 以 及 更 改 Smarty 模板 中 配 
置 文件 的 存储 路 径 等 。 


| 
实例 535 起 味 指数 : 裕 页 页 容 


图 实例 说 明 


在 本 实例 中 ,应 用 Oracle 数据 库 的 存储 过 程 技 术 , 实现 对 员工 信息 表 中 数据 的 更 新 操作 , 其 运行 结果 如 图 12.17 
所 示 。 


MN | 后 二 | | 
| # | 
; | 

[Em 
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12.17 存储 过 程 更 新 员工 信息 


力 关键 技术 


存储 过 程 是 为 执行 一 定 的 任务 而 组 合 在 以 前 的 SQL 和 /或 PL/SQL 语句 集 , 通常 由 以 下 几 部 分 组 成 : 声明 部 
分 、 执 行 部 分 和 异常 处 理 部 分 ， 其 中 执行 语句 是 必需 的 ， 而 其 他 两 部 分 则 是 可 选 的 。 

创建 存储 过 程 的 前 提 条 件 是 用 户 具 有 创建 过 程 的 权限 ， 这 个 权限 可 以 由 DBA 赋予 用 户 ， 其 语法 如 下 : 

GRANT CREATE ANY PROCEDURE TO UserName: 

取消 权限 的 语法 如 下 : 

REVOKE CREATE ANY PROCEDURE FROM UserName: 

Oracle 数据 库 中 创建 存储 过 程 的 语法 如 下 : 

CREATE[OR REPLACE] PROCEDURE procedure_name( 

argumentl[{inloutlin out}] type、 

argumentD[finloutin out] type 

Argument nf {inloutlin out}] type 


和 |as} 

<!-- 类 型 变量 的 说 明 --> 
BEGIN 
<!-- 执 行 部 分 --> 
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[EXCEPTION] 
<!-- 可 选 的 异常 处 理 部 分 -> 
END[procedure_name]; 


参数 说 明 : 

REPLACE: 关键 字 ， 为 可 选 值 ， 多 数 情况 下 会 使 用 。 其 作用 为 创建 存储 过 程 时 ， 如 果 同 名 过 程 已 经 存在 则 
删除 同名 过 程 ， 然 后 进行 创建 操作 。 有 一 点 需要 注意 ， 同 一 用 户 下 的 过 程 是 唯一 标识 的 ， 如 果 创 建 时 不 使 用 
REPLACE 关键 字 ， 当 出 现 同 名 过 程 时 ， 会 给 出 ORA-00955 错误 ， 表 示 名 称 已 经 被 现 有 对 象 使 用 。 

procedure_name: 创建 过 程 的 名 称 ， 它 在 数据 库 中 同一 用 户 下 是 唯一 标识 。 

argument: 过 程 的 参数 名 称 ， 为 可 选 参数 。 

站 、out、in out: 参数 的 模式 ， 默 认 的 模式 为 站。in 模式 为 输入 参数 模式 ， 具 备 只 读 属性 ， 不 可 以 在 执行 过 
程 中 赋值 ，out 模式 为 输出 参数 模式 ，in out 为 输入 /输出 参数 模式 。 

type: 指定 参数 的 数据 类 型 。 其 对 形 参 的 定义 只 可 以 指定 类 型 ， 不 可 以 限定 精度 。 

islas: 该 关键 字 到 BEGIN 关键 字 之 间 为 过 程 的 声明 部 分 。 声 明 包括 类 型 游标、 常量 、 变 量 、 异 常 和 棋 套 
子 程序 的 声明 ， 此 处 不 需 DECLARE 关键 字 ， 而 且 此 声明 部 分 中 声明 的 都 是 本 地 和 局 部 声明 ， 即 过 程 结 束 时 声 
明 终止 。 

BEGIN 关键 字 和 END 关键 字 之 间 为 过 程 的 执行 部 分 ,如 果 过 程 中 存在 异常 处 理 , 则 BEGIN 和 EXCEPTION 
关键 字 之 间 为 过 程 的 执行 部 分 ，EXCEPTION 和 END 关键 字 之 间 为 异常 处 理 部 分 。 

在 本 实例 中 创建 的 存储 过 程 如 下 : 


CREATE OR REPLACE PROCEDURE PROC USER( 
p_id IN integer, 
P_position IN VARCHAR 

)AS 

BEGIN 
‘update tb_user set position=p_position where id=p_id; 

commit; 
END PROC_USER: 


图 设计 过 程 

(1) 创建 conn 文件 ， 编 写 conn.php 文件 ， 完 成 与 Oracle 数据 库 的 连接 。 

(2) 创建 index.php 文件 ， 包 含 数据 库 连接 文件 ， 应 用 Oracle 函数 读 取 Oracle 数据 库 中 的 数据 ， 并 通过 
while 语句 完成 数据 的 循环 输出 。 创 建 form 表单 ， 完 成 员工 更 新 信息 的 提交 ， 将 更 新 数据 提交 到 index_ok.php 
文件 中 ， 其 关键 代码 如 下 : 

<Iphp 
include("conn/conn.php");: 
Squery="select * from tb_user "; 


Sresult=oci_parse($conn.$query); 
Sr = oci_execute(Sresult OCI DEFAULT): 


while($row=oci_fetch_array($result,OCI_ RETURN_NULLS){ 

?> 

<form id="form<?php echo $row[0]:?>" name="form<?php echo $row[0]:?>" method="post" action="update_ok.php"> 
<u> 


<td align="center" bgcolor="#FFFFFF"><?php echo $row[0]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[1]:?></td> 
<td align="center" bgcolor="#FFFFFF"> 
<input name="position" type="text" value="<?php echo $row[2]:?>" size="15" /> 
<input type="hidden" name="conn_id" value="<?php echo $row[0]:?>" /></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[3]:2></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $row[4]:?></td> 
<td align="center" bgcolor="#FFFFFF"><input type="submit" name="Submit" value=" 更 新 " /></td> 
<lt> 
</form> 
<?php 


oci_close($conn): 
> 


3) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 调 用 存储 过 程 完 成 员工 信息 的 更 新 操作 ， 其 关键 代 
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码 如 下 : 
<?php 
header ( "Content-type: text/html; charset=utf-8" ): /设置 文件 编码 格式 
include("conn/conn.php"); 
$sql = "BEGIN PROC_USER(:id, :positionj: END:"; // 定 义 SQL 语句 
$stmt = OCIParse($conn, $sql); /执行 SQL 语句 
/执行 绑 定 
OCIBindByName($stmt, ":id", $_ POST[conn id], 4): // 参 数 说 明 : 绑 定 PHP 变量 conn id 到 位 置 :id， 并 设 定 绑 定 长 度 为 4 位 
OCIBindByName($stmt, ":position", $_POST[position]. 50); 
if(OCIExecute($stmt)){ /调用 并 执行 存储 过 程 


echo "<script>alert(' 员 工 信 息 更 新 成 功 !);windowlocation href='index.php';</script>"; 
jelsef 
echo "<script>alert(' 员 工 信 息 更 新 失败 0):window ,location href='index php':</script>"; 
} 
> 


国 秘笈 心 ; 


心 法 领悟 535: 在 PHP 动态 页 中 调用 存储 过 程 。 

首先 定义 SQL 语句 ， 执 行 存储 过 程 中 的 更 新 语句 。 然 后 通过 ociparse0 函 数 配 置 Oracle 语句 预备 执行 。 接 
着 通过 OCIBindByName() 函 数 绑 定 一 个 PHP 变量 到 一 个 Oracle 标识 符 。 最 后 通过 OCIExecute0 函 数 执行 Oracle 
语句 ， 完 成 员工 信息 的 更 新 操作 。 


12.4 _ Oracle 数据 的 导入 和 导出 


本 节 将 介绍 Oracle 数据 库 中 数据 的 导入 、 导 出 方法 。 
高 级 | 
实例 536 起 味 指数 : 袖 女 亦 窑 


实例 说 明 EEC 


本 实例 将 Oracle 数据 库 中 的 数据 表 导 出 到 本 地 磁盘 C 盘 下 的 mrsoft a 6 证 
文件 夹 中 ,并 将 导出 的 文本 文件 命名 为 oracle.dmp。 导 出 的 结果 如 图 12.18 攻 | 
所 示 。 型 ， 1M 文件 修改 日 其 2. 00 好。 [ 卫 我 的 电脑 | 


12.18 ”导出 的 文本 文件 


图 关键 技术 


本 实例 应 用 Oracle 数据 库 中 数据 库 逻 辑 备份 工具 Export。 利用 Export 工具 可 以 在 数据 库 打 开 状态 下 备份 数 
据 库 。Export 把 数据 库 中 的 对 象 导出 到 一 个 二 进 制 文件 中 。 该 工具 也 是 数据 库 间 进行 迁移 的 一 个 工具 。 
Export 有 3 种 方法 : 行 命令 法 、 交 互 式 方法 和 参数 文件 方法 。 下 面 主要 介绍 本 实例 中 使 用 的 参数 文件 方法 。 


将 EXP 命令 的 各 个 参数 放 在 一 个 参数 文件 中 ， 参 数 文件 的 命令 格式 如 下 : 
EXP [用 户 名 | 口令 ] PARFILE = 参数 文件 路 径 及 名 称 


以 下 是 一 个 参数 文件 的 示例 ， 代 码 如 下 : 


FULL=Y 


INDEXES=Y 

其 中 ，FULL 设置 为 Y 时 ， 会 导出 除 SYS 方案 对 象 外 的 所 有 的 方案 对 象 ， 如 果 设 置 为 FULL， 要 求 用 户 有 
EXP_FULL_DATABASE 权限 ; FILE 参数 用 来 设置 导出 文件 的 目录 和 文件 名 ; GRANTS 参数 默认 值 为 Y， 用 来 
设置 是 否 导出 权限 信息 ; INDEXES 参数 默认 值 为 Y， 用 来 设置 是 否 导出 表 和 聚集 的 索引 。 
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图 设计 过 程 


(1) 选择 “开始 ”/“ 程 序 ”/“ 附 件 ”/“ 命 令 提 示 符 ”命令 ， 进 入 DOS 命令 环境 。 
(2) 在 DOS 提示 符 下 输入 “EXP 用 户 名 上 口令 命令 ” (EXP 不 区 分 大 小 写 ) ， 进 入 导出 界面 ， 代 码 如 下 : 


exp system/mrsoft tables=(tb_usertb_admin) file=C:\mrsoft\oracle.dmp 


(3) 按 Enter 键 ， 执 行 本 实例 ， 其 运行 结果 如 图 12.19 所 示 。 
加 


图 12.19 Oracle 数据 库 中 数据 表 的 导出 


心 法 领悟 536: Export 工具 导出 表 空 间 和 导出 数据 库 。 

通过 Export 工具 不 但 可 以 导出 表 ， 还 可 以 导出 表 空 间 、 分 区 和 数据 库 。 

(1) 导出 表 空 间 的 语法 如 下 : 

exp /demo/demo tablespaces=data 

(2) 导出 数据 库 ， 将 导出 所 有 的 数据 库 对 象 及 其 数据 ， 并 存储 到 指定 的 文件 系统 中 。 

@ 完全 导出 。 将 所 有 的 数据 库 对 象 及 数据 导出 到 文件 中 ， 并 为 积累 导出 和 增 量 导出 的 基点 安排 一 个 较 长 的 
周期 进行 完全 导出 ， 其 命令 如 下 : 

exp system/manager full=y inctype=complete file=export.dmp 


@ 增 量 导出 。 将 上 次 导出 以 来 已 经 发 生变 化 的 对 象 结构 及 数据 导出 到 文件 中 ， 其 命令 如 下 : 


exp system/manager full=y inctype=incremental file=export.dmp 


@ 积累 导出 ,将 上 次 进行 积累 或 完全 导出 以 来 已 经 发 生变 更 的 对 象 及 其 数据 库 导出 到 文件 中 , 其 命令 如 下 : 


exp system/manager full=y inctype=cumulative file=export.dmp 
ss 
实例 537 | 起 味 指数 : 庚 庚 友 家 
图 实例 说 明 


本 实例 讲解 将 文本 文件 中 的 数据 导入 到 Oracle 数据 库 中 。 数 据 的 导入 应 用 的 是 import 工具 ， 同 样 也 分 为 导入 
表 、 导 入 方案 和 导入 数据 库 3 种 。 在 本 实例 中 将 文本 文件 oracle.dmp 中 存储 的 数据 导入 到 Oracle 数据 库 中 。 


上 说 明 : 在 执行 将 文本 文件 中 的 数据 导入 到 Oracle 数据 库 时 ， 必 须 确保 在 Oracle 数据 库 中 不 存在 与 文本 文件 
中 同名 的 数据 表 ， 否 则 导入 操作 不 会 成 功 。 
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力 关键 技术 
(1) 导入 用 户 自身 所 拥有 的 表 ， 其 命令 如 下 : 


imp scott/tiger tables=(name.emp) file=export.dmp 
(2) 当 用 户 要 导出 其 他 方案 的 表 时 ， 必 须 具 备 DBA 角色 ， 或 者 被 赋予 EXP_ FULL DATABASE 角 
命令 如 下 : 
imp system/manger tables=(scott.name, scott.emp) file=exportdmp 
(3) 当 执行 导入 操作 时 ， 用 户 可 以 只 导入 表 结 构 而 不 导入 数据 ， 其 命令 如 下 : 
imp scott/tiger tables=(name, emp) file=export.dmp rows=n 
(4) 当 执 行 导 入 操作 时 ， 如 果 对 象 已 经 存在 就 可 以 只 导入 数据 ， 其 命令 如 下 : 
imp system/manager tables=(scottname,scottemp) file=export.dmp ignore=y 
图 设计 过 程 
(1) 选择 “开始 ”/“ 程 序 ”/“ 附 件 ”/“ 命 令 提 示 符 ” 命 令 ， 进 入 DOS 命令 环境 。 
(2) 在 DOS 提示 符 下 输入 “IMP 用 户 名 | 口令 命令 ”， 将 文本 文件 中 的 数据 导入 到 Oracle 数据 库 中 ， 代 
码 如 下 : 
imp system/mrsoft tables=( tb_user,tb_admin) file= C:\mrsoft\oracle.dmp 


(3) 按 Enter 键 ， 执 行 本 实例 ， 其 运行 结果 如 图 12.20 所 示 。 


[Ey 
并 


图 12.20 文本 文件 中 的 数据 导入 至 Oracle 


力 秘笈 心 法 
心 法 领悟 537: 导入 表 空 间 和 导入 整个 数据 库 。 
通过 import 工具 不 但 可 以 导入 表 ， 还 可 以 将 数据 导入 至 不 同 的 账户 ， 导 入 模式 、 表 空间 和 整个 数据 库 。 
导入 整个 数据 库 是 应 用 import 工具 将 文件 中 的 对 象 及 数据 导入 到 数据 库 中 。 
(1) 执行 导入 时 ， 需 要 导入 数据 库 损坏 前 最 新 的 信息 ， 其 命令 如 下 : 


imp system/manager fall=y file=export. dmp 


(2) 执行 导入 时 ， 需 要 导入 最 新 的 完全 导出 文件 信息 ， 其 命令 如 下 : 


imp system/manager full=y file=export.dmp 
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13.1 封装 ADODB 操作 类 
ADODB 是 Active Data Objects Data Base 的 简称 ， 是 一 种 PHP 存 取 数据 库 的 中 间 函 式 组 件 。 本 节 将 介绍 如 
何 对 ADODB 操作 数据 库 的 方法 进行 封装 ， 从 而 使 通过 ADODB 操作 数据 库 的 方法 更 加 简单 。 


[ED 说 明 : 因为 ADODB 属于 第 三 方 组 件 ， 所 以 在 本 书 的 光盘 中 没有 提供 ADODB 类 库 文 件 ， 需 要 读者 自行 下 
载 ， 并 复制 到 本 章 的 13 文件 天 下 ， 将 其 命名 为 adodb5， 然 后 才 可 以 运行 本 章 的 实例 。 


实例 S55 538 趣味 指数 袖 页 页 容 
图 实例 说 明 


连接 数据 库 类 的 封装 ， 意 味 着 通过 ADODB 连接 不 同 的 数据 库 的 方法 更 加 简单 、 更 容易 更 新 和 修改 。 只 要 
向 类 中 传递 对 应 的 参数 值 ， 即 可 完成 与 不 同 数据 库 服务 器 的 连接 。 在 本 实例 中 ， 以 MySQL 数据 库 服 务 器 为 例 ， 
实现 与 db_database13 数据 库 的 连接 ， 连 接 成 功 后 弹出 提示 信息 ， 其 运行 结果 如 图 13.1 所 示 。 


HH moors 


13.1 ADODB 连接 数据 库 类 


力 关键 技术 


ADODB 连接 数据 库 系统 使 用 ADONewConnection0 函 数 ; 如 果 选 择 持久 化 连接 则 使 用 PConnect0 函 数 ， 如 
果 选 择 非 持 久 化 连接 则 使 用 ConnectO) 函 数 。 
(1) ADONewConnection() 函 数 连接 数据 库 系 统 ， 其 语法 如 下 : 


ADONewConnection($databaseType) 

参数 $databaseType 表示 要 连接 的 数据 库 系 统 的 名 称 ， 如 mysql、mssql 等 。 
(2) PConnect0 函 数 实现 与 数据 库 的 持久 化 连接 ， 其 语法 如 下 : 
PConnect($host,[$user].[$password].[$database]) 

参数 说 明 : 

$host; 数据 库 系统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
$user: 数据 库 用 户 名 。 

Spassword: 数据 库 密 码 。 

$database: 使 用 到 的 数据 库 。 

(3) Connect0 函 数 实现 与 数据 库 的 非 持久 化 连接 ， 其 语法 如 下 : 


Conneet(Shost [Suserj[Spassword] [Sdatabasc]) 

参数 说 明 : 

$host: 数据 库 系统 的 服务 器 所 在 地 址 。 如 果 是 本 机 操作 ， 参 数值 为 localhost。 
$user: 数据 库 用 户 名 。 

Spassword: 数据 库 密码 。 

$database: 使 用 到 的 数据 库 。 
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掌握 连接 数据 库 服务 器 所 使 用 的 函数 之 后 ， 就 是 定义 类 、 方 法 和 参数 ， 完 成 与 指定 数据 库 服务 器 的 连接 并 


返回 连接 标识 ， 其 具体 代码 将 在 设计 过 程 中 进行 介绍 。 
图 设计 过 程 


(1) 创建 found.database.php 文件， 定义 ConnDB 连接 数据 库 类 ， 定 义 ConnDB( 方 法 为 成 员 变 量 赋值 ， 定 


义 GetConnId0 方 法 实现 与 不 同 数据 库 服务 器 的 连接 并 返回 连接 标识 ; 最 后 定义 CloseConnId0 方 法 关闭 数据 库 连 


接 ， 


其 关键 代码 如 下 : 


<?php 
/| 数据 库 连 接 类 
class ConnDB{ 
var $dbtype; /数据 库 服务 器 类 型 
var $host; /服务 器 名 称 
var $user; /用 户 名 
var Spwd; /密码 
var $dbname; /| 数据 库 名 称 
var $debug; // 是 否 返 回执 行 的 SQL 语句 ， 默 认 设置 为 返回 SQL 
var $conn; // 连 接 数据 库 时 返回 的 连接 标识 
function ConnDB($dbtype.$host$user,$pwd,Sdbname,Sdcbug=true)j{ /构造 方法 ， 为 成 员 变量 赋值 
Sthis->dbtype=$dbtype; 
Sthis->host=$host; 
Sthis->user=$user; 
Sthis->pwd=$pwd; 
Sthis->dbname=$dbname; 
Sthis->debug=$debug; 


} 
function GetConnIdO{ // 实 现 与 不 同 数据 库 的 连接 并 返回 连接 对 象 
require("../adodb$/adodb.ine.php"); /调用 ADODB 类 库 文件 
if($this->dbtype—"mysql" || $this->dbtype—"mssql"){ // 判 断 成 员 变量 传递 的 数据 库 类 型 
if($this->dbtype—"mysql") // 判 断 如 果 是 MySQL 数据 库 
Sthis->conn=NewADOConnection("mysql"): /| 执行 与 MySQI 数据 库 的 连接 
clse 
S$this->conn=NewADOConnection("mssql"); 
Sthis->conn->Connect($this->host.$this->user,$this->pwd.$this->dbname); // 数 据 库 连 接 的 用 户 、 密 码 
Jelseif($this->dbtype—"access"){ 1/ 判断 如 果 使 用 的 是 Access 数据 库 
Sthis->conn=NewADOConnection("aceess"); 
Sthis->conn->Connect("Driver={Microsoft Access Driver (*.mdb)}:Dbq=".$this->dbname.":Uid=".$this->user."; 


Pwd=".$this->pwd.";"); // 执 行 连接 Access 数据 库 
} 
S$this->conn->Execute("set names utf8"); // 设 置 数据 库 的 编码 格式 
if($this->dbtype—"mysql") 
S$this->conn->debug=$this->debug; 
returmn $this->conn: // 返 回 连接 对 象 
} 
function CloseConnIdO{ // 定 义 关闭 数据 库 的 方法 
S$this->conn->Disconnect(); 1/ 执行 关闭 的 操作 


lL 
} 


> 
(2) 创建 connect.database.php 文件 ， 实 例 化 数据 库 连 接 类 ConnDB 并 向 类 中 传递 对 应 的 参数 ， 完 成 与 


MySQL 数据 库 服务 器 中 db_database13 数据 库 的 连接 ， 其 关键 代码 如 下 : 
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es // 包 含 类 文件 
S$connobj=new ConnDB("mysql", "localhost". "root","111","db_database13",false): /| 数据 库 连 接 类 实例 化 
$conn=$connobj->GetConnIdO: /| 返回 连接 标识 
> 
(3) 创建 index.php 文件 ， 包 含 数据 库 连 接 类 的 实例 化 文件 ， 根 据 返 回 的 连接 标识 判断 数据 库 是 否 连 接 成 
其 关键 代码 如 下 : 
< 
人 'conn/connect database php': /包含 数 据 库 连接 类 的 实例 化 文件 
if($conn){ 


echo "<script>alert(' 数 据 库 连接 成 功 ! ):window .location href='http://www.mrbeed.com';</script>"; 
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Jelse{ 
echo "<script>alert(' 数 据 库 连接 失败 ! );window.location href=index.php';</script>"; 
} 


力 秘笈 心 法 


心 法 领悟 538: 通过 ADODB 连接 数据 库 服务 器 必须 注意 的 问题 。 

定义 连接 数据 库 类 ， 再 定义 连接 方法 GetConnId0 时 ， 必 须 先 通过 require 语句 包含 ADODB 类 库 文件 
adodb.incphp， 和 否则 其 他 一 切 操作 都 无 从 谈 起 。 

建议 在 程序 的 开发 阶段 运用 连接 数据 库 操 作 类 时 ， 将 参数 gdebug 的 值 设置 为 TRUE， 这 样 可 以 返回 执行 的 
SQL 语句 ,便于 获取 SQL 语句 在 执行 过 程 中 出 现 的 错误 。 如 果 是 在 生产 环境 中 运用 连接 数据 库 类 ， 那 么 就 要 将 
$debug 的 值 设 置 为 FALSE。 


高 级 | 


趣味 指数 : 依依 请 六 | 


实例 539 


力 实例 说 明 


既然 可 以 将 ADODB 连接 数据 库 的 方法 封装 到 类 中 ， 那 么 同样 也 可 以 将 ADODB 操作 数据 库 的 方法 封装 到 
类 中 。 本 实例 介绍 如 何 将 ADODB 操作 数据 库 的 方法 封装 到 类 中 ， 并 且 通 过 该 方法 读 取 MySQL 数据 库 服务 器 
的 db_database13 数据 库 中 tb_bccd 数据 表 中 的 数据 ， 其 运行 结果 如 图 13.2 所 示 。 


Han 

J 名 和 版 本 | 时 间 

1 VC 各 词典 标准 所 | 2010-07-29 
日 LL) 标准 所 | 2010-07-29 
3 Jur 程 词典 标准 所 | 2010-07-29 
‘ Ca 得 问 典 标准 并 | 20lo-07-29 
5 了 编程 词 内 标准 所 | 2010-07-29 
昌 CH 坟 程 亲 奥 标准 类 | 2010-07-29 
7 ET 标准 所 | 2010-07-29 
日 ET 标准 所 | 2010-07-29 
9 各 河内 标 | 2010-07-29 
10 | 办 公 自 动 化 过程 标准 折 | 2010-07-29 
四 硬件 给 护 编程 词典 一 标准 所 | 2010-07-29 
加 电 及 时而 编程 记 内 标准 折 | 2010-07-29 


13.2 ADODB 操作 数据 库 类 


力 关键 技术 


ADODB 操作 数据 库 类 为 AdminDB， 在 操作 数据 库 的 ExecSQL0 方 法 中 ， 关 键 是 以 下 几 个 函数 的 运用 。 
(1)strtolower0 函 数 将 字符 串 转换 为 小 写字 母 ， 其 语法 如 下 : 


string strtolower(string str) 
运用 本 函数 的 目的 是 将 SQL 语句 中 的 字符 串 都 转换 为 小 写 。 
(2) substrO 函 数 从 指定 的 字符 串 中 按照 指定 的 位 置 截取 一 定 长 度 的 字符 ， 其 语法 如 下 : 
string substr(string str.int start,int length) 
参数 说 明 : 
str: 指定 截取 的 字符 串 。 


PHP 开发 实例 大 全 (基础 卷 ) 


start: 指定 开始 截取 字符 串 的 位 置 ， 如 果 为 负数 ， 则 从 字符 串 的 末尾 开始 截取 。 
length: 可 选 参 数 ， 指 定 截取 字符 串 的 长 度 。 如 果 为 负数 ， 则 表示 取 倒 数 第 length 个 字符 。 


< 注意 : 本 函数 中 参数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 串 中 的 第 一 个 字符 表示 为 0。 


运用 substr0 函 数 对 SQL 语句 中 前 6 个 字符 串 进 行 截取 ， 其 目的 是 获取 SQL 语句 的 类 型 (insert、select 或 
者 update) ， 判 断 其 执行 的 是 什么 操作 。 
(3) trim0 函 数 删除 字符 串 中 首尾 的 空白 或 者 其 他 字符 。 
(4) execute0 函 数 为 ADODB 中 执行 SQL 语句 的 方法 并 返回 一 个 结果 集 (ADORecordSet 对 象 ) ， 失 败 则 
返回 FALSE， 其 语法 如 下 : 
execute($sql[,$inputarr=false]) 
参数 说 明 : 
$sql: 指定 要 执行 的 SQL 语句 。 
$inputarr: 设置 传 入 的 结合 变量 ， 如果 没 有 设置 Sinputarr， 则 $sql 为 普通 的 SQL 语句 ，execute0 函 数 的 格式 如 下 : 


S$connect->execute('select * from tb_user where id= 1) 


如 果 设置 了 $inputarr， 则 execute0) 函 数 的 格式 如 下 : 


S$connect -> execute('select * from tb_user where id = ?array(SvD) 


(5) GetRows() 函 数 是 GetArray0 的 同 义 函数 ， 是 为 了 与 Microsoft ADO 相 容 定义 的 ， 其 语法 如 下 : 


Ry 
返回 从 当前 指针 指向 的 记录 开始 , 到 $number_of rows - 1 行 的 全 部 记录 的 数组 。 参数 $number_of rows 表示 
指定 的 记录 行 ， 如 果 没 有 给 出 ， 则 一 直到 EOF 才 停 止 。 


图 设计 过 程 
(1) 创建 found.database.php 文件 ， 定 义 数据 库 操作 类 AdminDB， 定 义 ExecSQL0 方 法 ， 根 据 传 递 的 SQL 
语句 执行 对 数据 库 的 操作 。 在 ExecSQL0 方 法 中 ， 应 用 substr0 函 数 获取 参数 传递 的 SQL 语句 的 类 型 ， 然 后 根据 


SQL 语句 的 类 型 进行 判断 , 如 果 是 select 查询 语句 , 则 执行 GetRow() 方 法 , 获取 查询 结果 ; 如 果 是 update 、insert 
或 者 delete 语句 ， 则 直接 返回 TRUE 或 者 FALSE， 其 代码 如 下 : 


class AdminDB{ 
function ExecSQL($sqlstrSconn){ /定义 方法 ， 参 数 为 SQL 语句 和 连接 数据 库 返回 的 对 象 
$sqltype=strtolower(substr(trim($sqlstr).0,6)); /截取 SQL 中 的 前 6 个 字符 串 ， 并 转换 成 小 写 
Srs=$conn->Execute($sqlstr); /执行 SQL 语句 
if($sqltype=—"select"){ // 判 断 如 果 SQL 语句 的 类 型 为 select 
Sarray=$rs->GetRows(); // 执 行 该 语句 ， 获 取 查 询 结果 
if(count($array)—0 || $rs—false) // 判 断 语句 是 否 执行 成 功 
retum false: // 如 果 查 询 结果 为 0 或 者 执行 失败 ， 则 返回 FALSE 
else 
return $array; // 否 则 返回 查询 结果 的 数组 


}elseif ($sqltype—"update" || $sqltype 一 "insert" || $sqltype—"delete"){ 
// 判 断 如 果 SQL 语句 类 型 不 为 select、 则 执行 如 下 操作 


if($rs) 

Teturn true; // 执 行 成 功 返 回 TRUE 
else 

return false; // 否 则 返回 FALSE 


(2) 创建 connect.database.php 文件 ， 实 例 化 数据 库 连 接 类 ConnDB 和 数据 库 操作 类 AdminDB， 其 关键 代 
码 如 下 : 


<?php 
require("found.database.php"); // 包 含 类 文件 
Sconnobj=new ConnDB("mysql"."localhost". "root"."111"."db_database13".false): // 实 例 化 数据 库 连接 类 
$conn=$connobj->GetConnId(): // 返 回 连接 标识 
$admindb=new AdminDB(): // 实 例 化 数据 库 操作 类 
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(3) 创建 index.php 文件 ， 包 含 数据 库 连接 类 和 数据 库 操作 类 的 实例 化 文件 ， 定 义 SQL 语句 ， 调 用 数据 库 
操作 类 中 的 ExecSQL() 方 法 执行 SQL 查询 语句 , 最 后 通过 for 语句 循环 输出 ExecSQL( 方 法 返回 的 查询 结果 , 其 


关键 代码 如 下 : 
<?php 
include_once 'conn/connect database .php': // 包 含 数据 库 连 接 类 和 操作 类 的 实例 化 文件 
$sqlstr = 'select + from tb_bced'; // 定 义 SQL 语句 
Sarray = $admindb->ExecSQL($sqlstr,Sconn); // 调 用 数据 库 操作 类 中 的 方法 执行 查询 操作 
for($i=0;$i<count(Sarray);Si+){ // 通 过 for 循环 输出 数据 库 中 的 数据 
> 
<b> 


<td align="center" bgcolor="#FFFFFF"><?php echo $array[$i][0]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $array[$i][11:2></td> 
<td height="22" align="center" bgcolor="#FFFFFF"><?php echo $array{$i][2]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $array[$i][3]:?></td> 

</tr> 

<Iphp 

} 


> 


国 秘笈 心 法 


心 法 领悟 339: 判断 SQL 语句 类 型 的 技巧 。 

SQL 语句 的 类 型 分 为 查询 (select) 、 添 加 (insert) 、 更 新 update) 和 删除 (delete) 4 种 。 这 4 个 英文 单 
词 有 一 个 共同 的 特点 ， 即 都 是 由 6 个 英文 字母 组 成 ， 这 也 就 是 在 实例 中 应 用 substr0 函 数 对 SQL 语句 的 前 6 个 
字符 串 进 行 截取 的 原因 。 


ES i 
ee ee wa snes 
实例 说 明 


为 了 更 方便 地 通过 ADODB 操作 数据 库 中 的 数据 ， 这 里 对 ADODB 类 库 中 提供 的 分 页 函数 进行 整合 ， 封 装 
为 一 个 ADODB 分 页 类 ， 并 且 运 用 ADODB 分 页 类 输出 MySQL 数据 库 db_database13 中 tb_user 数据 表 中 的 数 
据 ， 其 运行 结果 如 图 13.3 所 示 。 


明日 科技 
共有 用 户 33 个 每 页 显示 10 个 第 2 页 共 9 页 首页 上 一 页 下 一 页 尾 页 


图 13.3 ADODB 分 页 类 的 应 用 


力 关键 技术 


在 ADODB 分 页 类 SepPage 中 ， 主 要 整合 下 面 几 个 ADODB 中 的 函数 。 
(1) PageExecute0 函 数 为 分 页 功能 函数 ， 其 语法 如 下 : 


PageExecute($sql, Snrows, $page): 
参数 说 明 : 
$sql: SQL 查询 语句 。 
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Snrows: 每 页 显示 的 记录 数 。 
Spage: 保存 当前 页 数 ， 默 认为 1。 


(2) AbsolutePage0 函 数 返 回 当 前 页 的 页 数 ， 其 语法 如 下 : 
AbsolutePage(Spage=-]) 


该 函数 要 与 PageExecute() 函 数 配合 使 用 。 
(3) AtFirstPage() 函 数 为 如 果 当 前 页 是 第 一 页 ， 则 返回 TRUE， 其 语法 如 下 : 


AtFirstPage($status=") 
该 函数 要 与 PageExecute0) 函 数 配 合 使 用 ， 判 断 当前 是 否 为 第 一 页 。 
(4) AtLastPage0 函 数 判 断 当前 页 是 否 为 最 后 一 页 ， 其 语法 如 下 : 


AtLastPage($status="); 
该 函数 同样 要 与 PageExecute0 函 数 配 合 使 用 ， 判 断 当前 页 是 否 为 最 后 一 页 ， 如 果 是 则 返回 TRUE。 
本 实例 中 整合 了 上 述 几 个 ADODB 类 库 中 的 函数 ， 封 装 了 一 个 ADODB 分 页 类 。 


图 设计 过 程 
(1) 创建 found.database.php 文件 ， 定 义 SepPage 分 页 类 ， 定 义 ShowData0 方 法 ， 读 取 数 据 库 中 存储 的 数 


据 ， 并 且 将 查询 结果 返回 到 数组 中 。 定 义 ShowPage0 方 法 ， 创 建 分 页 超 链 接 ， 完 成 从 数据 库 中 读 取 数 据 的 分 页 
输出 。SepPage 分 页 类 的 关键 代码 如 下 : 


class SepPage{ 
Var $rs; 
var Spagesize; 
Var $nowpage; 
var $array; 
Var $conn; 
Var $sqlstr 
function ShowData(Ssqlstr.Sconn.$pagesize,Snowpagcj{ /定义 方法 
ifl!isset(Snowpage) || Snowpage—"") // 判 断 变 量 值 是 否 为 空 
Sthis->nowpage=1; // 定 义 每 页 起 始 页 
clse 
Sthis->nowpage=$nowpage: 
Sthis->pagesize=$pagesize; // 定 义 每 页 输出 的 记录 数 
Sthis->conn=$conn; // 连 接 数 据 库 返 回 的 标识 
$this->sqlstr=$sqlstr /执行 的 查询 语句 
Sthis->rs=$this->conn->PageExecute($this->sqlstr,$this->pagesize. $this->nowpage); 
@$this->array=$this->rs->GetRows(); // 获 取 记 录 数 
if(eount($this->array)==0 || $this->rs—false) 
Teturn false; 
else 
Tetum $this->array: 
} 
/| 省略 了 ShowPage0 方 法 中 的 内 容 
} 


(2) 创建 connect.database.php 文件 ， 实 例 化 数据 库 连 接 类 ConnDB、 数 据 库 操作 类 AdminDB 和 分 页 类 
SepPage， 其 关键 代码 如 下 : 
< 


php 
require("found.database.php"); // 包 含 类 文件 
S$connobj=new ConnDB("mysql"."localhost". "root"."111"."db_database13".false): // 实 例 化 数据 库 连 接 类 
S$conn=$connobj->GetConnId(): 
S$admindb=new AdminDB0: // 实 例 化 数据 库 操作 类 
S$seppage=new SepPage(): /实例 化 分 页 类 
> 


(3) 创建 index.php 文件 ， 包 含 connect.database.php 文件 ， 调 用 分 页 类 中 的 ShowData() 方 法 ， 完 成 数据 的 
分 页 输出 ， 调 用 分 页 类 中 的 ShowPage0 方 法 输出 分 页 的 超 链接 ， 其 关键 代码 如 下 : 


<?php 

include_once 'conn/connect.database.php'; // 调 用 类 中 方法 
Sarray=$seppage->ShowData("select + from tb_user".$Sconn,10.$_GET["page"]); /| 分 页 读 取 数据 库 中 数据 
for($i=0;$i<count($array):$i++){ /| 循环 输出 数据 库 中 数据 
> 
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<tr> 
<td height="20" align="center" bgcolor="#FFFFFF"><?php echo $array[$i][0]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $array[$i][1]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $array[$i][2]:?></td> 
</tr> 
<?php 
} 
?> 
<t> 
<td height="35" ><?php echo $seppage->ShowPage(" 用 户 "," 个 "." 参 数 1"" 参 数 2","a1"):?></td> 
<ltr> 


心 法 领悟 540: ADODB 分 页 类 的 运用 技巧 。 
在 运用 ADODB 分 页 类 进行 数据 的 分 页 输出 时 ， 向 ShowData() 方 法 中 传递 4 个 参数 ，SQL 查询 语句 、 数 据 


库 的 连接 标识 、 每 页 显示 的 记录 数 和 当前 页 码 ; 向 ShowPage0 方 法 中 传递 5 个 参数 : 数据 的 类 型 、 数 据 的 单位 、 
超 链 接 的 参数 一 、 参 数 二 和 超 链接 样式 。 


13.2 ADODB 的 应 用 


ADODB 类 库 非 常 大 ， 仅 一 个 adodb.inc.php 文件 就 有 120KB 。 本 节 将 详细 讲解 ADODB 类 库 中 的 连接 数据 
库 函 数 、 操 作 数 据 库 函 数 、 公 用 变量 、 公 用 函数 、 结 果 集 处 理 函数 和 错误 处 理 函数 等 在 实例 中 的 具体 应 用 。 


高 级 | 
mo | ee 


力 实例 说 明 


在 实例 540 中 介绍 了 如 何 将 ADODB 中 的 分 页 函数 封装 到 类 中 ， 并 通过 分 页 类 完成 数据 的 循环 输出 操作 。 
而 在 本 实例 中 ， 则 还 原 分 页 函数 的 本 来 面貌 ， 通 过 面向 过 程 的 方法 编写 一 个 数据 分 页 输出 的 实例 ， 了 解 分 页 函 
数 的 具体 应 用 。 本 实例 的 运行 结果 如 图 13.4 所 示 。 


13.4 ADODB 分 页 函数 的 应 用 


力 关键 技术 


有 关 ADODB 类 库 中 分 页 函数 的 详细 介绍 可 以 参考 实例 540 关键 技术 中 的 内 容 ， 这 里 不 再 袭 述 。 在 本 实例 
中 引入 rs2html0 函 数 ， 直 接 将 PageExecute() 函 数 返 回 的 查询 结果 以 表格 的 形式 输出 。 
Is2html0 函 数 返回 一 个 HTML 表格 格式 的 结果 集 ， 其 语法 如 下 : 


rs2html(Srst[Stable_attributes]. [Scol_titles]) 
参数 说 明 : 
S$rst: 要 返回 的 结果 集 。 
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S$table_attributes: 对 表格 的 参数 及 属性 的 设置 。 
$col titles: 对 字段 的 重新 命名 。 


4) 注意 : 运用 rs2html0 函 数 的 前 提 是 必须 载 入 tohtml.iniphp 文件 。 
图 设计 过 程 


(1) 创建 comn 文件 夹 ， 编 写 conn .php 文件 ， 载 入 adodb.iniphp 文件 。 实 现 与 MySQL 数据 库 服务 器 中 
db_database13 数据 库 的 连接 ， 并 设置 数据 库 的 编码 格式 为 UTF-8， 其 代码 如 下 : 


<php 

include_once (adodbs/adodb inc php); // 载 入 (include) adodb inc.php 文件 
$conn = ADONewConnection(mysql): // 建 立 连接 

$conn -> PConnect(localhost,'root,'l11','db_database13"): // 连 接 数 据 库 

S$conn -> execute('set names utf8"): // 设 置 编码 格式 


?> 

(2) 编写 index.php 文件 。 首 先 包 含 数 据 库 连 接 文件 conn.php， 然 后 载 入 tohtml.ini.php 文件 ， 最 后 定义 
SQL,， 应 用 ADODB 类 库 中 的 分 页 函数 完成 数据 的 分 页 输出 ， 并 且 应 用 rs2html0 函 数 直接 将 分 页 查询 的 数据 定 
义 到 表格 中 ， 其 关键 代码 如 下 : 


<?php 
include_once 'conn/conn.php'; // 载 入 数据 库 连接 文件 
include (../adodbS/tohtml .ine.php’); // 载 入 tohtmlinc.php 文件 
$sql = 'select* from tb_bced': /查询 语句 
Snum = 3; // 每 页 显示 的 记录 数 
if(isset ($_GET ['n_page])) { // 判 断 当前 页 码 
$c _ page =$_GET ['n_page']: // 将 Sn_page 赋 给 变量 $c_apge 
}elsef 
Se _page=1; // 初 始 化 变量 $c_page 
Srst = $conn->PageExecute ( $sql, $num, $c_page ); /执行 PageExecute0 函 数 
if (false != $rst) { 
?> 
<tr> 
<td><7 


rs2html ( $rst, width="775" border="1" align="center" cellpadding="1" cellspacing="1" bordercolor="#FFFFFF" 
bgcolor="#999999", array (TD'' 名 称 '' 类 型 ,添加 时 间 ' ) ); 
?><hd> 
/省 略 了 部 分 代码 
<?php 
} 


> 


国 秘笈 心 法 


心 法 领悟 541: 将 分 页 读 取 的 数据 存储 到 缓存 中 。 

了 PageExecute0 函数 可 以 执行 分 页 功能 ， 但 是 如 果 要 将 分 页 查询 的 结果 存储 到 缓存 中 ， 就 必须 使 用 
CachePageExecute($sec, $sql, Snrows, Spage) 函 数 , 其 不 但 具备 PageExecute0 函 数 的 功能 , 而 且 可 以 将 显示 后 的 记 
录放 到 缓存 中 。 在 $sec 秒 内 ， 如 果 需 要 重复 查看 ， 将 从 缓存 中 读 取 数据 。 


高 级 | 
实例 542 趣味 指数 ， 裕 页 诬 家 
实例 说 明 


在 ADODB 类 库 中 ， 不 只 提供 了 分 页 函数 ， 还 提供 了 封装 好 的 分 页 类 供 开 发 者 使 用 。 在 本 实例 中 ， 运 用 
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ADODB 类 库 中 提供 的 ADODB pager 类 实现 分 页 功能 ， 分 页 输出 编程 词典 的 注册 用 户 ， 其 运行 结果 如 图 13.5 
所 示 。 


| 


必 39 首页 上 -页 下 -页 尾 页 


13.5 ADODB pager 分 页 类 


力 关键 技术 


ADODB_Pager0 函 数 是 ADODB_Pager 类 的 构造 函数 ， 通 过 类 中 的 render0 函 数 可 以 实现 分 页 功能 ， 其 语法 
如 下 : 


ADODB_ Pager(Seonn, $sql, Sid = 'adodb' SshowPageLinks = false) 
参数 $conn 是 数据 库 连 接 对 象 ， 参数 $sql 是 执行 的 SQL 语句 ;参数 $id 为 每 个 分 页 的 id 号 ; 参数 
$showPageLinks 设置 是 否 显 示 各 个 页 的 链接 ， 默 认为 FALSE。 


安 提示 : 应 用 ADODB_pager() 函 数 实现 分 页 功能 的 前 提 条 件 是 必须 载 入 adodb-pager.ini.php 文件 。 
图 设计 过 程 

(1) 创建 com 文件 夹 ， 编 写 conn.php 文件 ， 载 入 adodb.iniphp 文件 。 实 现 与 MySQL 数据 库 服务 器 中 
db_database13 数据 库 的 连接 ， 并 设置 数据 库 的 编码 格式 为 UTF-8， 其 代码 如 下 : 


<Iphp 


include_once ('../adodb$/adodb.ine.php’); // 载 入 (include) adodb.ine.php 文件 
$conn = ADONewConnection('mysql); /建立 连接 

$conn -> PConnect('localhost,root"111'db_database130): /连接 数据 库 

$conn -> execute('set names utf8"); // 设 置 编码 格式 


> 


(2) 创建 index.php 文件 ， 完 成 数据 的 分 页 输出 。 首 先 包含 数据 库 连接 文件 ， 然 后 载 入 adodb-pager.ini.php 
文件 ， 最 后 实例 化 ADODB_Pager 类 ， 调 用 Render0 方 法 ， 设 置 每 页 显示 10 条 记录 ， 其 关键 代码 如 下 : 


< 


include ‘conn/conn.php'; // 载 入 数据 库 连 接 文件 
include_once ' adodb-pager ine.php'; // 载 入 adodb-pageriiniphp 文件 
诈 声明 对 象 */ 


S$pager = new ADODB_Pager($conn,"select id.user as ' 用 户 名 ', pass as ' 密 码 ',dates as ' 注 册 时 间 ' from tb_user"); 
履 ”调用 Render0 函 数 确定 每 页 显示 多 少 记录 */ 

Spager -> Render(10): 

> 


力 秘笈 心 法 

心 法 领悟 542: 修改 ADODB_Pager 类 中 定义 的 分 页 方法 的 样式 。 

修改 ADODB_Pager 类 中 定义 的 分 页 方法 的 样式 ， 即 对 载 入 的 adodb-pager.ini.php 文件 进行 修改 。 可 以 修 
改 的 内 容 包括 超 链 接 、 表 格 背 景 、 宽 度 、 边 框 宽度 和 颜色 等 。 在 本 实例 中 ， 将 超 链接 修改 为 中 文 并 且 重 新 定 
义 了 表格 的 宽度 。 为 了 便于 读者 使 用 , 还 将 修改 后 的 adodb-pager.iniphp 从 ADODB 类 库 中 复制 到 实例 的 根 目 
录 下 。 
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力 实例 说 明 


通过 ADODB 类 库 操 作 数据 库 ， 不 但 要 掌握 数据 库 的 连接 方法 ， 还 要 掌握 操作 结果 集 的 方法 。 在 本 实例 中 
将 介绍 ADODB 类 库 中 操作 结果 集 的 方法 ， 并 且 应 用 其 中 的 方法 循环 输出 数据 表 中 的 字段 和 值 ， 其 运行 结果 如 
13.6 所 示 。 


图 13.6 ADODB 操作 结果 集 的 方法 


力 关键 技术 


当 使 用 execute0) 函 数 执行 SQL 指令 时 ， 会 回 传 一 个 ADORecordSet 对 象 。 通 过 对 ADORecordSet 对 象 的 控 
制 ， 可 以 对 结果 集 进行 很 多 操作 。 操 作 结果 集 的 方法 如 下 : 
(1) fields 
该 变量 保存 的 是 当前 指针 所 指向 的 记录 。 
(2) EOF 
该 变量 记录 当前 指针 是 否 指向 最 后 一 条 记录 。 如 果 是 ， 则 设 定 为 TRUE， 否 则 为 FALSE。 
(3) GetArray([$number_of rows]) 
返回 从 当前 指针 指向 的 记录 开始 ， 到 $number_of rows-1 行 的 全 部 记录 的 数组 。 参 数 $number_of rows 表示 
指定 的 记录 行 ， 如 果 没 有 给 出 则 一 直到 EOF 才 停 止 。 
(4) MoveNextO 
函数 作用 : 将 ADORecordSet〔 结 果 集 〉 的 指针 下 移 一 位 。 如 果 成 功 则 返回 TRUE， 否 则 返回 FALSE。 
(5) Move($to) 
函数 作用 : 将 ADORecordSet (结果 集 ) 的 指针 移动 到 指定 位 置 。 如 果 $to 等 于 0， 则 指针 指向 结果 集 的 第 
一 条 数据 ， 如 果 $to 的 值 大 于 结果 集 ， 则 指针 指向 最 后 一 条 数据 。 注 意 ， 这 里 的 变量 $to 只 能 是 绝对 定位 。 
(6) MoveFirstO 
函数 作用 : 将 指针 移动 到 第 一 条 数据 ， 等 同 于 Move(0)。 
(7) MoveLast0 
函数 作用 : 将 指针 移动 到 最 后 一 条 数据 ， 等 同 于 Move(RecordCount0-1) 


二 
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(8) FetchRowO 
函数 作用 : 返回 当前 指针 指向 的 记录 的 数组 ， 如 果 是 EOF， 回 传 FALSE。FetchRow0 不 能 和 MoveNext0 


混用 。 


(9) FetchField($column number) 
函数 作用 : 返回 一 个 对 象 ， 包 含 字段 $column_number 的 名 称 、 空 间 长 度 等 相关 信息 。 
参数 $column_number 是 要 查看 的 字段 名 称 。 
(10) FetchNextObject([$toupper=true]) 
函数 作用 : 返回 当前 指针 所 指向 的 记录 的 对 象形 式 ， 并 且 指 针 自 动 下 移 一 行 。 
参数 gtoupper 如 果 等 于 TRUE， 则 字段 名 为 大 写 形式 。 
(11) FieldCountO 
函数 作用 : 返回 结果 集 里 的 字段 数 。 
(12) RecordCountO 
函数 作用 : 返回 结果 集 里 的 记录 数 。 
(13) MetaType($nativeDBType [,$field max length],[$fieldobj]) 
函数 作用 : 标准 化 不 同 数据 库 系统 下 的 数据 类 型 的 表示 法 。 处 理 不 同 的 数据 库 系统 有 一 个 问题 ， 即 每 一 个 
数据 库 系统 对 于 相同 的 数据 类 型 会 有 不 同 的 表示 法 ， 比 如 支持 超 长 文本 的 类 型 ， 有 的 表示 为 text， 有 的 表示 为 
long character， 还 有 的 表示 为 clob 等 。MetaType0 函 数 可 以 将 这 几 种 表示 方法 统一 起 来 ， 如 用 大 写字 母 D 来 表 
示 所 有 的 日 期 类 型 ， 用 大 写字 母 T 表示 所 有 的 时 间 类 型 。 
参数 说 明 : 
SnativeDBType: 数据 表 中 的 数据 类 型 。 
$fields_max_length: 字段 最 大 长 度 。 
$fieldsobj: 字段 对 象 。 
MetaType0 函 数 支 持 的 标准 化 数据 类 型 有 : 


C: 


因 办 办 办 办 办 办 了 多 
吕 避 轨 日 田 X 


be 


支持 char、varchar 等 字符 类 型 。 


: 支持 text、long character 等 长 类 型 。 
: blob 或 binary image。 


日 期 date。 


: 时 间 timestamp。 

: 逻辑 类 型 和 位 类 型 。 

: 包含 编号 、 整 型 、 浮 点 型 等 数字 类 型 。 
: 包含 序列 、 自 动 增加 整数 等 序列 类 型 。 


图 设计 过 程 

(1) 创建 comn 文件 夹 ， 编 写 conn.php 文件 ， 载 入 adodb.iniphp 文件 。 实 现 与 MySQL 数据 库 服务 器 中 
db_database13 数据 库 的 连接 ， 并 设置 数据 库 的 编码 格式 为 UTF-8。 

(2) 创建 index.php 文件 ， 包 含 数据 库 连 接 文件 ， 定 义 SQL 查询 语句 ， 通 过 execute0 函 数 执行 查询 操作 ， 
通过 FieldCount 0 函数 统计 字段 数量 ,应 用 for 语句 和 FetchField0 函 数 循环 输出 各 个 字段 的 值 ,并 应 用 metaTypeO 
函数 对 字段 中 的 数据 类 型 进行 判断 ， 同 时 应 用 DBDate0 函 数 对 时 间 进 行 格式 化 ， 其 关键 代码 如 下 : 


<Iphp 

include_once 'conn/conn.php': // 载 入 数据 库 连接 文件 

Scount = 1; 

$sqlstr = 'select * from tb_object where id=". $count: //SQL 查询 语句 

S$rst = $conn->execute ( $sqlstr ) or die ( 'error: '. $conn->errorMsg 0 ): /执行 查询 语句 

if(false (= $rst) { // 如 果 有 查询 结果 
for($i = 0: $i< $rst->FieldCount 0: $i ++) { /| 循环 输出 各 个 字段 

Sfields = Srst->FetchFicld ( $i ): /生成 字段 信息 对 象 
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Stype = $fields->type: 
> 
‘<td bgcolor="#FFFFFF"> 
<?php 
/从 对 象 中 获取 字段 的 类 型 信息 


证 (Srst>metaType ( $type, - 1, $fields ) — "T") // 如 果 标 准 类 型 为 
echo $conn->DBDate ( $rst->fields [$i] ); // 使 用 DBDate0 函 数 格式 化 时 间 


echo Srst->fields [$i]: // 如 果 是 其 他 类 型 ， 直 接 输出 
?> 
<htd> 
Fe 


} 
?> 


图 秘笈 心 法 


心 法 领悟 543: 操作 结果 集 方法 的 运用 。 

在 本 实例 中 ， 只 是 使 用 FieldCount0 函 数 和 FetchField0 函 数 对 数据 表 中 的 字段 进行 操作 。 在 实例 544 中 ， 
将 应 用 EOF 、fields 和 movenext0 函 数 以 及 while 语句 完成 数据 表 中 数据 的 循环 输出 , 其 实现 的 是 结果 集中 行 的 
操作 。 


BE 


力 实例 说 明 


在 实例 543 中 介绍 了 很 多 操作 结果 集 的 方法 ， 本 实例 继续 应 用 上 一 实例 中 介绍 的 操作 结果 集 方法 ， 对 数据 
表 中 的 行进 行 操作 ， 循 环 输出 数据 表 中 的 数据 。 同 时 应 用 一 个 新 的 方法 ， 实 现 对 结果 集 存 取 方 式 的 控制 ， 其 运 
行 结果 如 图 13.7 所 示 。 


高 级 
赤 味 指数 : 请 庚 育 安 


ED 《a> 
图 13.7 ADODB 类 库 中 对 数据 库 中 数据 输出 的 控制 


力 关键 技术 


在 通过 对 SQL 语句 的 操作 之 后 ， 多 数 都 会 返回 一 个 结果 集 (ADORecordSet 对 象 ) 。 通 过 对 ADORecordSet 
对 象 的 控制 ， 可 以 对 结果 集 进行 各 项 操作 ， 这 里 介绍 的 是 如 何 控制 结果 集 的 存 取 方 法 。 
1. SADODB_COUNTRECS 


当 该 变量 为 TRUE 时 ，RecordCount0 函 数 会 在 数据 库 驱 动 不 支 持 select 指令 返回 的 记录 总 数 时 进行 自动 模 
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拟 ， 返 回 记 录 数 ， 默 认 值 为 TRUE。 每 次 进行 查询 操作 时 都 会 自动 检查 该 变量 的 值 。 此 功能 十 分 消耗 内 存 ， 不 
建议 使 用 。 
2. SADODB_CACHE DIR 


该 变量 设置 缓存 目录 ， 一 般 在 使 用 缓存 函数 时 用 到 ， 如 CacheExecute0 函 数 。 

3. SADODB _ FETCH_MODE 

该 变量 决定 结果 集 以 哪 种 方式 进行 存 取 ， 有 4 个 值 : 

(1) define(ADODB FETCH DEFAULT'.0) 

结果 集 按照 默认 的 方式 进行 存 取 ， 该 默认 方式 依据 数据 库 驱 动 程序 而 有 所 不 同 。 

(2) define(ADODB FETCH NUM'1) 

结果 集 以 字段 序号 为 索引 进行 存 取 ， 如 Srst -> fields[0]、Srst -> fields[1]。 

(3) define(ADODB FETCH ASSOC',2) 

结果 集 以 字段 名 称 为 索引 进行 存 取 ， 如 Srst -> fields[bigclass]、Srst -> fields[id]。 

(4) define(ADODB FETCH BOTH'3) 

结果 集 同 时 支持 (2) 、 (3) 两 种 方式 。 如 果 未 设置 该 变量 ， 默 认 值 为 《1) ， 不 同类 型 的 数据 库 驱 动 默认 
值 也 不 相同 。 这 里 不 建议 使 用 变量 (4) ， 因 为 有 很 多 的 驱动 并 不 支持 。 


图 设计 过 程 
(1) 创建 com 文件 夹 ， 编 写 conn.php 文件 ， 载 入 adodb.iniphp 文件 。 实 现 与 MySQL 数据 库 服务 器 中 


db_database13 数据 库 的 连接 , 应 用 SADODB_FETCH MODE 设置 结果 集 以 字段 名 称 为 索引 进行 存 取 , 并 设置 数 
据 库 的 编码 格式 为 UTF-8， 其 代码 如 下 : 


<?php 

include_once ('Jadodbsladodb ,inc php)); // 载 入 adodb ini .php 文件 

$conn = ADONewConnection('mysql); /连接 MySQL 数据 库 

S$conn -> PConnect('localhost',root,'111','db_database13"); // 连 接 db_database13 数据 库 
$ADODB_FETCH_MODE = ADODB_FETCH _ASSOC:; 1/ 设置 结果 集 以 字段 名 称 为 案 引 进行 存 取 
S$conn -> execute('set names utf8"); // 设 置 编 码 格式 


> 
(2) 创建 index.php 文件 ， 完 成 数据 的 循环 输出 。 首 先 包含 数据 库 连 接 文 件 ， 然 后 定义 SQL 查询 语句 ， 通 
过 execute0) 函 数 执行 查询 操作 ， 最 后 通过 while 语句 循环 输出 查询 结果 ， 其 关键 代码 如 下 : 


< 

ee // 载 入 数据 库 连 接 文 件 
$sqlstr = 'select + from tb_user where id limit 5'; //SQL 查询 语句 

S$rst = $conn->execute ( $sqlstr ) or die ( 'error: '. $conn->errorMsg 0 ); // 执 行 查询 语句 

while ( ! $rst->EOF ) { // while 语句 循环 输出 结果 
?> 


<tr> 
<td width="126" height="30" align="center"><?php echo S$rst->fields [user]; ?></td> 
<td width="117" align="center"><?php echo Srst->ficlds ['dates']; ?></td> 

<t> 


<2php 
S$rst->movenext (): /指针 下 移 
小 
S$rst->close (0: /关闭 连接 
$conn->close 0: 
> 
图 秘笈 心 法 


心 法 领悟 544: 结果 集 存 取 方 式 的 选择 。 
在 关键 技术 中 已 经 对 ADODB 类 库 中 结果 集 的 存 取 方 式 进行 了 详细 介绍 ， 至 于 如 何 选择 ， 需 要 根据 实际 情 
况 具 体 分 析 ， 也 可 以 不 设置 结果 集 的 存 取 方式 。 建 议 读者 以 字段 名 称 为 索引 进行 数据 存 取 ， 这 样 在 获取 数据 值 
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时 更 准确 一 些 ， 不 会 因为 数据 表 中 字段 的 添加 或 者 删除 而 影响 到 获取 的 值 。 


力 实例 说 明 


在 实际 的 程序 开发 中 ， 如 果 要 实现 数据 在 不 同 数据 库 服务 器 之 间 的 转换 ， 最 理想 的 方法 就 是 编写 一 个 数据 
转换 的 程序 。 这 就 是 本 实例 中 要 向 大 家 展示 的 内 容 ， 即 同时 连接 两 个 不 同 的 数据 库 服务 器 ， 完 成 数据 由 MySQL 
数据 库 到 Access 数据 库 的 转换 。 运 行 本 实例 ， 单 击 图 13.8 中 的 “导出 ”按钮 ， 将 MySQL 数据 库 中 的 数据 导入 
到 Access 数据 库 中 ， 单 击 “查看 ACCESS” 超 链接 将 看 到 如 图 13.9 所 示 的 存储 于 Access 数据 库 中 的 数据 。 


2014-04-08 00:00:00 
2014-04-08 00:00;00 


2014-04-03 00:00:00 


2014-04-03 00:00:00 
2014-04-03 00:00:00 
2014-04-03 00:00:00 
2014-04-03 00:00:00 
#9 TA 1 2014-04-03 00:00:00 
0 2014-04-03 00-00-00 
a 2010-04-0? 00:00:00 


图 13.8 ”MySQL 数据 库 中 的 数据 图 13.9 ”Access 数据 库 中 的 数据 
图 关键 技术 


一 次 连接 两 个 数据 库 ， 即 同时 执行 两 次 ADONewConnection0 函 数 和 PConnect0 函 数 ， 分 别 指定 不 同 的 
MySQL 数据 库 服务 器 和 Access 数据 库 服务 器 。 

在 连接 MySQL 服务 器 时 ， 设 置 的 用 户 名 是 root， 密 码 是 111， 指 定 的 数据 库 是 db_database13， 设 置 编码 格 
式 为 UTF-8。 

在 连接 Access 服务 器 时 ， 指 定 的 数据 库 是 db_database13.mdb， 注 意 这 里 必须 设置 Access 数据 库 文件 在 服 
务 器 中 的 绝对 路 径 。 


同时 连接 两 个 数据 库 的 代码 如 下 : 

<?php 

include_once(, Jadodbsladodb inc.php); // 载 入 (include) adodb.inc .php 文件 
$conn = ADONewConnection( mysql'); // 建 立 连 接 

$conn -> PConnect('localhost,'root','111','db_database13"); // 连 接 数 据 库 

$conn -> execute('set names utf8): /| 设置 编码 格式 

$con = ADONewConnection("access"); // 连 接 Access 数据 库 

$con-> PConnect("Driver={Microsoft Access Driver (*.mdb)}:Dbq=F:\\AppServ\\www\\mr\13\\008\\conn\\data\\db_database13.mdb"); 
S$con-> execute('set names gb2312"): /设置 编码 格式 


?> 
将 从 MySQL 数据 库 中 读 取 的 数据 添加 到 Access 数据 库 中 ， 应 用 的 是 ADODB 类 库 中 的 GetImsertSQLO 函 
该 函数 用 于 向 数据 库 中 添加 新 的 记录 ， 其 语法 如 下 : 


GetInsertSQL(&S$rs, SarrFields) 


参数 $rs 设置 要 添加 记录 的 结果 集 ; 参数 $arFields 设置 新 记录 的 字段 值 及 字段 名 称 。 


号 


兴 
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图 设计 过 程 


(1) 创建 conn 文件 ， 编 写 conn.php 文件 ， 完 成 与 两 个 数据 库 服 务 器 的 连接 ， 其 代码 请 参考 关键 技术 中 的 
内 容 。 

(2) 创建 index.php 文件 , 将 从 MySQL 数据 库 中 读 取出 的 数据 通过 GetInsertSQLO 函 数 添 加 到 Access 数据 
库 中 ， 并 且 在 本 页 中 输出 MySQL 数据 库 中 的 数据 ， 同 时 创建 导出 和 查看 Aceess 数据 库 中 数据 的 超 链 接 ， 其 关 


键 代码 如 下 : 

<2php 
include ("conn/conn.php"); 
$sql = "select * from tb_user where id limit 5 "; /创建 SQL 语句 
Srst = $conn->execute ( $sql ) or die (‘error: '. $conn->errorMsg 0 ): // 执 行 查询 语句 
Sarray = array (); 
while ( ! S$rst->EOF ) { 

Sarray [id] = $rst->fields ['id']:; # process Sarr 

Sarray [user]= iconv ( "utf-8", "gb2312", $rst->fields [user] ); # process Sarr 

ee pe 

Sarray [dates] = $rst->ficlds ['dates']; # process Sarr 

这 ($_GET ['insert] 一 "导出") { 


$sqls = "select * from tb_user where id=0 "; // 创 建 SQL 语句 
Sret = $con->execute ( $sqls ) or die (‘error: '. $con->errorMsg 0 ); // 执 行 查询 语句 
Sinsert = $con->getInsertSQL ( $ret, $array ) or die (update error: '. $con->errorMsg () ); /添加 新 数据 


Scon->execute ( $insert ); 


} 
?> 
<tr> 
<td><?php echo Srst->ficlds [id]; ?></td> 
<td height="20"><?php echo Srst->ficlds ['user']; 2></td> 
<td><?php echo Srst->ficlds [dates ?></td> 
</t> 


<?php 


Srst->movenext (); /指针 下 移 
ee 0: /关闭 连接 
Sn 0; 
3) 创建 access.php 文件 ， 包 含 数据 库 连 接 文 件 conn.php， 完 成 Access 数据 库 中 数据 的 循环 输出 。 
图 秘笈 心 法 


心 法 领悟 545: 通过 ADODB 连接 Access 数据 库 。 

通过 ADODB 连接 Access 数据 库 时 ， 在 设置 数据 库 文件 的 存储 位 置 时 ， 必 须 指定 数据 库 文件 在 服务 器 中 的 
绝对 路 径 。 同 时 为 了 Access 数据 库 文 件 的 安全 ， 可 以 为 Access 数据 库 设 置 密码 。 

选择 Access 菜单 栏 中 的 “工具 ”/“ 安 全 ”/“ 设 置 数据 库 密码 ”命令 可 设置 Access 数据 库 的 密码 ;选择 
Access 菜单 栏 中 的 “工具 ”/“ 安 全 ”/“ 撤 销 数据 库 密码 ”命令 ， 在 弹出 的 “撤销 数据 库 密码 ”对 话 框 中 输入 设 
置 时 的 密码 ， 即 可 撤销 该 数据 库 的 密码 。 


实例 546 趣味 指教 走 丰 让 向 | 


力 实例 说 明 


在 MySQL 数据 库 中 有 一 个 limit 关键 字 ， 通 过 它 可 以 控制 select 查询 语句 从 第 几 条 记录 开始 查询 及 查询 多 
少 条 记录 。 而 在 ADODB 中 也 有 一 个 limit 关键 字 ， 就 是 SelectLimit0 函 数 ， 它 模拟 limit 关键 字 ， 控 制 select 查询 
语句 的 执行 。 在 本 实例 中 就 应 用 SelectLimit0 函 数 , 查询 班级 中 前 3 名 学 生 的 成 绩 , 其 运行 结果 如 图 13.10 所 示 。 
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D p ~ 


用 户 登录 icginm 成 级 寿 询 


或 绩 


图 13.10 ”SelectLimit0 函 数 查询 班级 前 3 名 学 生 的 成 绩 


力 关键 技术 


ADODB 中 的 SelectLimit0 函 数 模拟 limit 关键 字 ， 控 制 select 查询 语句 的 执行 。 但 要 注意 ，SelectLimit0 函 
数 的 参数 位 置 与 MySQL 数据 库 中 limit 关键 字 是 不 同 的 。SelectLimit0 函 数 的 语法 如 下 : 


SelectLimit($sql[,Snumrows—=1][.Soffset=-1][,Sinputarr=false]) 
参数 说 明 : 
$sql: 要 执行 的 select 查询 语句 。 
Snumrows: 要 查询 的 记录 数 。 如 果 该 值 为 -1， 则 查询 到 最 后 一 条 记录 。 
$offset， 表 示 从 第 几 条 记录 开始 查询 。 
S$inputarr: 结合 变量 。 
图 设计 过 程 
(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 服 务 器 中 db_database13 数据 库 的 
连接 。 
(2) 创建 index.php 文件 ， 包 含 数据 库 连接 文件 ， 定 义 SQL 查询 语句 ， 应 用 SelectLimitO 函 数 查询 出 班级 
前 3 名 学 生 的 成 绩 ， 并 且 循 环 输出 查询 结果 ， 其 关键 代码 如 下 : 


<?php 

include_once (connjconn php)): // 载 入 adodb.ini.php 文件 
$sql="select * from tb_student where id order by grade dese"; // 定 义 查询 语句 
$numrows =3; /设置 查询 的 记录 数 
Soffset= 0; // 设 置 起 始 位 置 


S$rst = $conn -> SelectLimit($sql.Snumrows.$offset) or die('execute error: '.$conn -> ErrorMsg()): // 执 行 查询 
while(!$rst -> EOF){ 
> 


<tr> 
<td height="25" align="center"><?php echo $rst -> fields['studentname']:?></td> 
<td align="center"><?php echo Srst -> fields['classname']; ?></td> 
<td align="center"><?php echo S$rst -> fields['grade']: ?></td> 
<t> 
<?php 
Srst -> movenext(); /指针 下 移 
} 
Srst -> close0: // 关 闭 连接 
S$conn -> close0: 
> 
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心 法 领悟 546: 明确 SelectLimit0 函 数 与 MySQL 数据 库 中 limit 关键 字 的 区 别 。 
在 SelectLimitO 函 数 中 ，$numrows 指定 的 是 要 查询 的 记录 数 ，$offset 指定 从 第 几 条 记录 开始 查询 ， 而 在 
MySQL 数据 库 中 ，limit 关键 字 指定 查询 的 开始 位 置 ， 而 offset 指定 查询 的 记录 数 。 


力 实例 说 明 


在 ADODB 类 库 中 ， 有 一 种 方法 可 以 返回 表格 式 的 结果 集 ， 即 将 查询 结果 直接 以 表格 的 形式 进行 输出 。 本 
实例 就 应 用 这 种 方法 循环 输出 编程 词典 的 数据 ， 其 运行 结果 如 图 13.11 所 示 。 


高 级 


J 
| 
趣味 指数 : 本 


序号 名 称 类 别 时 间 


1 VC 议程 间 典 标准 版 
2 VB 编程 闻 典 标准 版 
3 JAVA 编 程 闻 奥 标准 版 


图 13.11 ADODB 生成 HTML 表格 


图 关键 技术 


本 实例 应 用 rs2html0 函 数 返回 一 个 HTML 表格 格式 的 结果 集 ， 其 语法 如 下 : 
function rs2html($adorecordset [Stableheader_ attributes]. [Scol_titles]) 


参数 说 明 : 

$adorecordset: 要 返回 的 结果 集 。 

S$tableheader_attributes: 对 表格 的 参数 及 属性 的 设置 。 

$col_titles: 对 字段 的 重新 命名 。 

要 运用 本 函数 ， 必 须 载 入 ADODB 类 库 中 的 tohtml.inc.php 文件 。 


图 设计 过 程 
(1) 创建 comn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 
(2) 创建 index.php 文件 ， 包 含 数 据 库 连 接 文 件 ， 定 义 SQL 查询 语句 ， 应 用 rs2html0 函 数 将 查询 结果 以 表 
格 的 形式 输出 ， 其 关键 代码 如 下 : 
<php 


include_once ‘conn/conn.php'; // 载 入 数据 库 连接 文件 

include_once '../adodb5S/tohtml inc.php'; // 载 入 tohtmlinc.php 文件 

S$rst = $conn -> execute('select + from tb_becd"): // 返 回 查询 结果 集 

Ts2html($rst' width="775" border="1" cellpadding="1" cellspacing="1" bordercolor=" 考 FFFFF" bgcolor"#CCCCCC",array( 序 号 名 称 '' 类 别 '" 时 间 
六 

> 


图 秘笈 心 ; 
心 法 领悟 547: rs2html0 函 数 。 
这 是 一 个 独立 的 函数 (rs2heml = recordset to html) ， 相 当 于 PHP 中 的 odbc result_all0 函 数 。 它 输出 一 个 完 
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整 的 ADORecordSet， 参 数 $adorecordset 如 同一 个 HIML 表格 ; 参数 $tableheader attributes 允许 控制 表格 中 的 
参数 ， 如 cellpadding、cellspacing 或 者 border 等 属性 。 最 后 通过 $col titles 参数 ， 设 置 数据 表 中 字段 的 名 称 。 注 
意 ， 该 函数 是 一 种 快速 除 错 机 制 ， 并 不 是 一 个 理想 的 结果 集 输出 方法 。 


实例 548 


力 实例 说 明 


在 ADODB 中 ,有 一 种 方法 可 以 将 结果 集中 的 数据 直接 
以 下 拉 列 表 框 的 形式 返回 , 这 种 方法 非常 适合 论坛 中 的 帖子 
标题 或 者 类 别 的 输出 ， 也 可 以 在 登录 用 户 的 权限 选择 中 使 
用 。 在 本 实例 中 , 应 用 这 种 方法 完成 用 户 登录 时 编程 词典 类 
型 的 选择 ， 其 运行 结果 如 图 13.12 所 示 。 


图 关键 技术 


ADODB 中 生成 下 拉 列 表 框 应 用 的 是 GetMenu0 函 数 。 
GetMenu0) 函 数 返回 一 个 HTML 下 拉 列 表 框 〈select) 。 结 果 集 的 第 一 列 〈fields[0]) 被 显示 到 下 拉 列 表 中 。 
第 二 列 (fields[1]) 被 设置 为 <option> 标 签 的 value 属性 ， 其 语法 如 下 : 


GetMenu($name, [$default_str="], [$blank=true], [$multiple_select=false], [Ssize=0]. [SmoreAttr="]) 

参数 说 明 : 

$name: 下 拉 列 表 框 的 名 称 。 

$default_str: 如 果 $default_str 的 值 等 于 其 中 一 个 fields[0], 那么 这 个 fields[0] 就 是 该 下 拉 列 表 框 的 默认 选项 。 
相当 于 为 这 个 fileds[0] 添 加 了 属性 <selected>。 

$blank: 该 参数 默认 值 为 TRUE。 在 生成 下 拉 列 表 框 时 ， 第 一 行 选项 默认 为 空 ， 即 <option></option>。 如 果 
为 FALSE， 则 没有 默认 的 空 选 项 。 

$multiple_select; 是 否 支持 多 选 ， 默 认 值 为 FALSE， 即 不 允许 。 

$size: 选取 列表 框 的 大 小 ， 默 认为 0， 生 成 一 个 下 拉 列 表 框 。 如 果 $size 的 值 大 于 0， 则 生成 一 个 列表 框 。 

$moveAttr: 该 参数 可 以 增加 列表 框 的 属性 ， 如 添加 一 个 JavaScript 脚本 等 。 


看 设计 过 程 
(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 


(2) 编写 index.php 文件 ， 创 建 form 表单 ， 设 置 action 属性 值 为 index_ok.php。 包 含 数据 库 连接 文件 ， 定 
义 SQL 查询 语句 ， 应 用 GetMenu20 函 数 将 查询 结果 以 下 拉 列 表 框 的 形式 输出 ， 其 关键 代码 如 下 : 


图 13.12 ADODB 生成 下 拉 列 表 框 


?php 

include_once 'conn/conn.php': // 载 入 数据 库 连 接 文 件 
$sqlstr = 'select name,id from tb_bccd': /SQL 查询 语句 

S$rst = $conn -> execute($sqlstr) or die('‘execute error: '.$conn -> errorMsgO): // 执 行 查询 语句 ， 返 回 结果 集 
> 


<!-- 调用 GetMenu20 函 数 --> 
<?php echo $rst -> GetMenu2('type'$_POST['name'] ,false); ?> 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 完 成 用 户 的 登录 操作 。 
秘 稚 心 > 


心 法 领悟 548: 生成 下 拉 列 表 框 的 另 一 个 函数 一 一 GetMenu20。 
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在 本 实例 中 运用 的 并 不 是 关键 技术 中 讲解 的 GetMenu0 函 数 而 是 GetMenu20 函 数 。GetMenu20) 函 数 的 作 
用 与 GetMenu0 函 数 相 同 ， 它 们 之 间 的 区 别 是 : GetMenu0 中 的 参数 Sdefault_str 和 fields[0] 比 较 ， 如 果 相 等 ， 
那么 fields[0] 就 是 这 个 下 拉 列 表 框 的 默认 选项 ， 而 GetMenu20 中 的 参数 $default_str 则 是 和 fields[1] 进 行 比较 ， 
其 他 不 变 。 


es 


起 味 指数 : 庚 砍 友 容 | 


力 实例 说 明 


事务 处 理 机 制 在 程序 开发 过 程 中 有 非常 重要 的 作用 ， 它 可 以 使 整个 系统 更 加 安全 ， 例 如 在 银行 处 理 转账 业 
务 时 ， 如 果 A 账户 中 的 金额 刚 被 发 出 ， 而 B 账户 还 没 来 得 及 接受 就 发 生 停电 事故 ， 这 会 给 银行 和 个 人 带 来 很 
大 的 经 济 损失 。 采 用 事务 处 理 机 制 一 旦 在 转账 过 程 中 发 生意 外 ， 则 程序 将 回 滚 不 做 任何 处 理 。 在 本 实例 中 ， 沿 
用 实例 545 的 内 容 , 实现 数据 在 不 同 数据 库 间 的 转换 功能 , 在 将 MySQL 数据 库 中 的 数据 转换 到 Access 数据 库 
中 后 ， 删 除 MySQL 数据 库 中 的 原始 数据 ， 并 应 用 事务 处 理 机 制 保证 数据 转换 操作 安全 、 顺 利 地 进行 。 运 行 本 
实例 ， 如 图 13.13 所 示 ， 单 击 “数据 转 移 ” 超 链接 ， 将 MySQL 数据 库 中 的 数据 转移 到 Access 数据 库 中 ， 并 且 
删除 MySQL 数据 库 中 的 原始 数据 。 单 击 “ 查 看 ACCESS” 超 链接 ， 将 查看 到 Access 数据 库 中 存储 的 数据 ， 如 
图 13.14 所 示 。 


ja 
JavaSeript 


图 13.13 数据 转移 13.14 ”查看 Access 数据 库 中 的 数据 


力 关键 技术 


在 ADODB 中 ， 事 务 处 理应 用 的 是 如 下 3 个 函数 : 

(1) BeginTrans0 函 数 ， 开 启事 务 处 理 。 该 函数 和 下 面 的 两 个 函数 都 是 应 用 在 PHP 的 事务 处 理 中 。 

(2) CommitTrans0 函 数 ， 如 果 成 功 完成 数据 库 操作 则 执行 该 函数 。 

(3) RollbackTrans0 函 数 ， 结 束 一 次 操作 ， 恢 复 操 作 前 的 所 有 改变 。 如 果 成 功 返 回 TRUE， 如 果 服 务 器 不 
支持 则 返回 FALSE。 


图 设计 过 程 
(1) 创建 conmn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 
(2) 编写 index.php 文件 ， 包 含 数据 库 连接 文件 ， 定 义 SQL 语句 ， 循 环 输出 MySQL 数据 库 中 的 数据 ， 通 


过 BeginTrans() 函 数 开 启事 务 处理 。 然 后 根据 超 链接 传递 的 参数 进行 判断 ， 通 过 GetInsertSQLO 函 数 执 行 数据 的 
转移 操作 ， 转 移 成 功 后 通过 delete 语句 删除 原始 数据 库 中 的 数据 。 最 后 根据 添加 语句 和 删除 语句 的 执行 情况 ， 
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判断 是 执行 CommitTrans 0 提交 操作 还 是 执行 RollbackTrans 0 回 滚 操作 ， 其 关键 代码 如 下 : 


<php 

include ("conn/conn.php"): 

$sql = "select* from tb_user where id order by id limit 5 "; /创建 SQL 语句 
Srst = $conn->execute ( $sql ) or die (‘error: '. $conn->errorMsg 0 ); /| 执行 查 询 语句 
Sarray = array (); 

$con->BeginTrans (); // 开 始 事务 处 理 
S$conn->BeginTrans (); // 开 始 事务 处 理 


while ( !Srst->EOF ) { 
站 ($_GET ['insert] 一 "数据 转移 ") { 
Sarray [id] = S$rst->fields [id"l; # process $arr 
Sarray [user] = iconv ( "utf-8", "gb2312", $rst->fields [user] ); # process Sarr 
Sarray ['pass'] = $rst->fields [pass']; # process $arr 
Sarray [dates] = $rst->fields ['dates']; # process $arr 
$sqls = "select * from tb_user where id=0 "; /创建 SQL 语句 
Sret = $con->execute ( $sqls ) or die ('emror: '. $con->errorMsg 0 ); // 执 行 查询 语句 
Sinsert = $con->getInsertSQL ( $ret, $array ) or die ( update error: '. $con->errorMsg 0 ); /添加 新 数据 
Sresult=$con->execute ( $insert ); 
$sql ='delete from tb_user where id = . Srst->ficlds [id]: JWSQL 删除 语句 
Sresults = $conn->execute ( $sql ) or die ( 'execute error: '. $conn->ErrorMsg 0 ); /执行 删除 语句 


?> 
<t> 
<td><?php echo Srst->ficlds ['id']: ?></td> 
<td height="20"><?php echo S$rst->ficlds [user]; ?></td> 
<td><?php echo Srst->ficlds ['dates]; ?></td> 


<t> 
<?php 
S$rst->movenext (); /指针 下 移 
} 
if(Sresul){ 
$con->CommitTrans (); /执行 提交 
证 (Sresults) { 
S$conn->CommitTrans 0: /| 执行 提交 
}else{ 
S$conn->RollbackTrans 0: /| 执行 回 滚 操作 
jelse{ 
$con->RollbackTrans (); /| 执行 回 滚 操作 
} 
S$rst->close 0; // 关 闭 连接 


Sconn->close |; 
?> 


(3) 创建 access.php 文件 ， 循 环 输出 Access 数据 库 中 存储 的 数据 。 
国 秘笈 心 法 

心 法 领悟 549: 什么 是 事务 。 

事务 是 指 一 个 或 一 系列 的 查询 ， 这 些 查询 或 者 全 部 执行 或 者 全 部 不 执行 ， 其 作用 是 在 服务 器 发 生 错误 或 崩 
溃 的 情况 下 确保 数据 库 的 一 致 性 。 

一 个 事务 被 永久 地 写 入 到 数据 库 中 称 为 事务 提交 ， 将 状态 重 置 到 事务 开始 之 前 的 状态 称 为 事务 回 滚 。 事 务 
具有 以 下 4 个 特性 : 

(1) 原子 性 : 指 事务 作为 一 个 整体 或 者 完全 执行 ， 或 者 完全 不 执行 。 

(2) 一 致 性 : 指 一 个 事务 必须 能 够 使 数据 处 于 一 致 的 状态 。 

(3) 孤立 性 : 在 事务 完全 完成 之 前 ， 它 们 都 是 孤立 的 。 

(4) 持续 性 : 一 旦 写 入 数据 库 后 ， 事 务必 须 是 永久 的 、 持 续 的 。 
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13.3 ADODB 中 的 错误 处 理 


力 实例 说 明 

ADODB 提供 很 多 操作 数据 库 的 方法 和 函数 ， 这 其 中 不 乏 错误 处 理 机 制 和 程序 调试 的 方法 。 在 本 实例 中 将 
介绍 一 种 程序 调试 的 方法 。 通 过 该 方法 将 输出 程序 中 执行 的 SQL 语句 ， 如 果 SQL 语句 编写 错误 ， 那 么 将 输出 
错误 信息 ， 其 运行 效果 如 图 13.15 所 示 。 


(mysql): select * from 由 use where id limit 5 


图 13.15 输出 SQL 语句 中 的 错误 信息 


图 关键 技术 


输出 系统 中 执行 的 SQL 语句 ,应 用 的 是 ADODB 中 的 debug 变量 。 如 果 变 量 被 设 定 为 TRUE， 当 有 输出 
操作 时 ， 同 时 也 输出 调试 信息 ; 如 果 启 用 debug 变量 ， 当 错误 发 生 时 ， 将 自动 调用 ErrorMsgO 函 数 返 回 错 误 
信息 。 

ErrorMsg0 函 数 返 回 最 后 的 状态 或 出 错 信息 , 即使 没有 错误 发 生 , 也 会 返回 一 个 字符 串 。 所 以 ,一般 情况 下 ， 
只 有 在 发 生 错误 时 (返回 FALSE) 才 调用 该 函数 。 


图 设计 过 程 
(1) 创建 conmn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 


(2) 编写 index.php 文件 。 首 先 包 含 数据 库 连接 文件 ， 设 置 debug 变量 的 值 为 TRUE， 开 启 调试 功能 。 然 
后 定义 SQL 语句 ， 循 环 输出 MySQL 数据 库 中 的 数据 。 最 后 关闭 连接 和 数据 库 ， 其 关键 代码 如 下 : 
php 


include ("conn/conn php");: 


$conn -> debug = true; /开启 调试 
$sql = "select * from tb_use where id limit 5 "; /| 创建 SQL 语句 
S$ret = $conn->execute ( $sql ) ; /执行 查询 语句 
while ( ! $ret->EOF ) { // 循 环 输出 
?> 
<t> 
<td height="20"><?php echo $ret->fields[0]: ?></td> 
<td height="20"><?php echo $ret->fields[1]: «~ ?></td> 
<td><?php echo $ret->fields[3]; ?></td> 
</tr> 
<?php 
Sret->movenext (); // 指 针 下 移 
Sret->close 0: /| 关闭 连接 
$conn->close (): 
> 
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图 秘笈 心 法 


心 法 领悟 550: 合理 地 运用 debug 调试 功能 。 

debug 变量 的 调试 功能 适合 在 程序 开发 过 程 中 运用 ， 通 过 它 可 以 及 时 发 现 SQL 语句 中 的 错误 。 但 是 在 实际 
的 应 用 环境 中 ， 必 须 关 闭 该 调试 功能 。 为 了 确保 程序 数据 库 的 安全 ， 如 果 存 在 SQL 语句 的 错误 ， 最 好 不 要 让 浏 
览 者 看 到 。 


图 实例 说 明 

本 实例 将 介绍 ADODB 类 库 中 另外 一 种 程序 调试 的 方法 , 该 方法 可 以 在 
程序 发 生 错 误 时 返回 错误 信息 ， 其 效果 如 图 13.16 所 示 。 

关键 技术 图 13.16 返回 错误 信息 


ErrorMsg0 函 数 返 回 最 后 的 状态 或 出 错 信息 ， 即 使 没有 错误 发 生 也 会 返回 一 个 字符 串 。 所 以 多 数 情 况 下 ,其 
与 die0 函 数 联 合 使 用 ， 在 执行 的 SQL 语句 发 生 错 误 时 (返回 FALSE) 才 调 用 该 函数 。 


图 设计 过 程 
(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 
(2) 编写 index.php 文件 。 首 先 包 含 数据 库 连 接 文件 。 然 后 定义 SQL 语句 ， 通 过 execute() 函 数 执行 SQL 


语句 , 应 用 die0 函 数 在 SQL 语句 的 执行 发 生 错 误 时 , 调用 ErrorMsg0 函 数 返 回 错误 信息 。 最 后 循环 输出 MySQL 
数据 库 中 的 数据 ， 其 关键 代码 如 下 : 


和 | 


起 味 指数 : 页 庚 页 宙 | 


Frrergsg 返 回 铺 误 信息 


Te dh_taabaselitn os dotsrt exst 
四 。 用 记名 时 间 


<?php 
include ("conn/conn.php"); 
$sql = "select * from tb_use where id limit 5 "; // 创 建 SQL 语句 
Sret = $conn -> execute($sql) or die($conn -> ErrorMsgO); // 执 行 查询 语句 并 返回 错误 信息 
while (! $ret->EOF ) { /循环 输出 
> 
<t> 


<td height="20"><?php echo Sret->ficlds[0]: a ?></td> 
<td height="20"><?php echo Sret->ficlds[1]: ?></td> 
<td><?php echo $ret->fields[3]; ?></td> 

</tt> 


<?php 
Sret->movenext (); /指针 下 移 


} 

Sret->close (): // 关 闭 连 接 
Sconn->close (); 

> 


图 秘笈 心 法 


心 法 领悟 551: 合理 地 运用 ErrorMsgO 函 数 返回 SQL 语句 的 错误 信息 。 

ErrorMsg0 函 数 返回 最 后 的 状态 或 出 错 信息 ， 其 特点 是 无 论 SQL 语句 是 否 出 错 都 会 返回 一 个 字符 串 ， 这 就 
要 求 在 应 用 ErrorMsg0 函 数 时 必须 注意 。 为 避免 在 SQL 语句 执行 正确 的 情况 下 返回 字符 串 , 在 SQL 语句 的 执行 
发 生 错误 时 运用 ErrorMsg0 函 数 是 最 佳 方案 。 
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实例 552 起 味 指数 : 请 庚 育 家 | 


目 


力 实例 说 明 


本 实例 将 介绍 ADODB 类 库 中 提供 的 自 定义 错误 处 理 机 制 , 通过 这 种 机 
制 可 以 调用 PHP 的 函数 error reportingO 控 制 错误 信息 的 显示 。 在 本 实例 中 
将 返回 所 有 的 错误 信息 ， 其 运行 结果 如 图 13.17 所 示 。 


图 关键 技术 图 13.17 返回 所 有 错误 信息 


ADODB 中 提供 的 这 个 自 定义 错误 处 理 机 制 存 储 于 adodb-errorhandler.inc.php 文件 中 ， 通 过 它 可 以 调用 
PHP 的 函数 error_reporting0) 控 制 错 误 信息 的 输出 样式 。 


< 注意 : 应 用 ADODB 中 提供 的 自 定义 错误 处 理 机 制 时 ， 必 须 在 程序 连接 数据 库 服务 器 之 前 载 入 
adodb-errorhandler.inc.php 文件 。 


图 设计 过 程 


(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 。 首 先 设置 error reportingO 函 数 的 值 为 E_ALL， 显 示 所 有 的 错 
误 信息 。 然 后 载 入 adodb-errorhandler.inc.php 文件 。 最 后 完成 与 MySQL 数据 库 的 连接 ， 其 代码 如 下 : 


<2php 

error_reporting(E_ALL); // 显 示 所 有 的 错误 信息 
include_once ("../adodb$/adodb-errorhandler ine.php); 

include_once ('../adodb$ /adodb.inc.php'); // 载 入 adodb ini.php 文件 

$conn = ADONewConnection('mysql );: /| 连接 MySQL 数据 库 

$conn -> PConnect(localhost',‘root,'111','db_database13); /| 连接 db_database13 数据 库 
/SADODB_FETCH MODE = ADODB FETCH ASSOC: /设置 结果 集 以 字段 名 称 为 索引 
$conn -> execute('set names utf8"); // 设 置 编码 格式 


> 

(2) 编写 index.php 文件 。 首 先 包含 数据 库 连 接 文 件 。 然 后 定义 SQL 语句 ， 通 过 execute0 函 数 执行 SQL 
语句 。 最 后 循环 输出 MySQL 数据 库 中 的 数据 ， 其 关键 代码 如 下 : 

<2php 


include ("conn/conn.php"); 

$sql = "select * from tb_use where id limit 5 ": // 创 建 SQL 语句 
Sret = $conn -> execute($sql); // 执 行 查询 语句 
while ( ! $ret->EOF ) { /循环 输出 


<td height-"20"><?php echo $ret->fields[0]; ?><ltd> 

<td height="20"><?php echo Sret->fields[1]: ?></td> 

<td><?php echo Sret->fields[3]: ?></td> 

$ret->movenext (); /1/ 指 针 下 移 
Sret->close (|); // 关 闭 连接 


力 秘笈 心 法 


心 法 领悟 552: 通过 error_reporting0 函 数控 制 返回 的 错误 信息 。 
在 本 实例 中 ， 设 置 error_reporting0 函 数 的 值 为 E_ALL 将 返回 所 有 的 错误 信息 。 如 果 将 值 设 置 为 0， 将 不 会 
有 任何 错误 信息 输出 。 如 果 想 更 多 地 了 解 error_reporting0 函 数 ， 请 参考 PHP 函数 手册 。 
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实例 553 攻 福 件 中 高 级 


力 实例 说 明 


略 式 人 0 可 看 WW 需 助 好 


在 实例 552 中 , 只 是 应 用 ADODB 类 库 中 提供 的 自 定义 错误 处 理 
el 和 musql error: [1146: Table 引 


机 制 返回 所 有 的 错误 信息 ， 在 本 实例 中 将 介绍 另外 一 种 错误 处 理 机 

制 ， 不 但 可 以 返回 错误 信息 ， 而 且 可 以 将 错误 信息 存储 到 指定 的 文件 | 人 ee eon se were lotdl ae 司 
中 。 在 本 实例 中 ， 将 返回 的 错误 信息 存储 于 根 目录 下 的 error 文件 夹 en i 
中 ，errorlog 中 的 错误 信息 如 图 13.18 所 示 。 图 13.18 通过 日 志文 件 存储 错误 信息 


图 关键 技术 


同样 ， 应 用 ADODB 中 提供 的 自 定义 错误 处 理 机 制 时 ， 必 须 在 程序 连接 数据 库 服务 器 之 前 载 入 adodb- 
errorhandler.inc.php 文件 。 

将 错误 信息 存储 于 指定 的 文件 中 ， 应 用 的 是 两 个 选择 性 常量 : ADODB_ERROR LOG TYPE 和 ADODB_ 
ERROR LOG _DEST。 

将 ADODB_ERROR LOG TYPE 的 值 设置 为 3， 即 将 错误 信息 存储 于 常量 ADODB_ERROR LOG DEST 
指定 的 文件 中 。 这 里 指定 ADODB_ERROR_LOG DEST 的 值 为 error/error.log， 即 将 错误 信息 存储 于 实例 根 目录 
下 error 文件 夹 的 error.log 文件 中 。 


图 设计 过 程 
(1) 创建 conn 文件 夹 编写 conn.php 文件 。 首 先 定义 两 个 常量 ， 设 置 程序 中 错误 信息 的 存储 位 置 。 然 后 载 
入 adodb-errorhandler.inc.php 文件 。 最 后 完成 与 MySQL 数据 库 的 连接 ， 其 代码 如 下 : 


<?php 

define(ADODB_ERROR LOG TYPE'3): // 设 置 类 型 
define(ADODB_ERROR LOG DEST',error/error.log'): // 设 置 存储 路 径 
include_once ('../adodb5/adodb-errorhandler.inc.php’): // 载 入 自 定义 错误 处 理 文件 
include_once ('../adodb5/adodb.ine.php’): // 载 入 adodb.ini.php 文件 
$conn = ADONewConnection('mysql); /连接 MySQL 数据 库 
S$conn -> PConnect('localhost',root,'111','db_database13"); // 连 接 db_database13 数据 库 
S$conn -> execute('set names utf8); // 设 置 编码 格式 


> 

(2) 编写 index.php 文件 。 首 先 包 含 数 据 库 连 接 文件 。 然 后 定义 SQL 语句 ， 通 过 execute0 函 数 执行 SQL 
语句 。 最 后 循环 输出 MySQL 数据 库 中 的 数据 ， 其 关键 代码 如 下 : 

<?php 


inelude ("conn/conn.php"): 


$sql = "select * from tb_use where id limit 5 "; // 创 建 SQL 语句 
Sret = $conn -> execute($sql); // 执 行 查询 语句 
while ( ! $ret->EOF ) { /循环 输出 


<td height="20"><?php echo Sret->ficlds[0]: a ?></td> 
<td height="20"><?php echo Sret->fields[1]: ?></td> 
<td><?php echo $ret->fields[3]: ?></td> 


<i> 
<?php 

Sret->movenext (); // 指 针 下 移 
} 
Sret->close (|: /关闭 连接 
S$conn->close 0: 
和 2 
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心 法 领悟 553: ADODB _ ERROR LOG TYPE 常量 设置 错误 记录 的 类 型 。 

用 ADODB_ERROR LOG TYPE 常量 设置 错误 记录 的 类 型 ， 可 选 值 如 下 : 

0: 默认 值 。 根 据 php.ini 文件 中 的 error log 配置 ， 错 误 被 发 送 到 服务 器 日 志 系统 或 文件 。 
1: 错误 被 发 送 到 destination 参数 中 的 地 址 。 只 有 该 类 型 使 用 headers 参数 。 

2: 通过 PHP debugging 连接 来 发 送 错误 。 该 选项 只 在 PHP 3 中 可 用 。 

3: 错误 被 发 送 到 文件 目标 字符 串 。 


加 回回 加 


13.4 ADODB 操作 数据 库 


Eee 一 一 as 
趣味 指教 : 请 请 斌 穴 | 


图 实例 说 明 


虽然 PHP 是 构建 Web 系统 强 有 力 的 工具 ， 但 是 由 于 PHP 存 取 函 数 一 直 没有 标准 化 ， 不 同 数据 库 间 的 函数 
名 称 、 参 数 差异 很 大 ， 在 更 换 数据 库 时 ， 会 带 来 大 量 的 代码 修复 工作 。 这 时 ， 就 需要 一 组 函数 库 来 隐藏 不 同 数 
据 库 函数 间 的 差异 ， 使 开发 者 可 以 很 简单 地 去 切换 数据 库 ， 这 就 是 ADODB 类 库 。 

本 实例 中 ， 应 用 ADODB 访问 Access 数据 库 ， 并 通过 分 页 函数 实现 数据 库 中 数据 的 分 页 输出 ， 其 运行 结果 


如 图 13.19 所 示 。 
nN 亲人 丙 玉英 芒 束 及 着 们 
A 明日 图 书 网 
ne me 


8 再 -页 了 着 


13.19 ADODB 分 页 输出 Access 数据 库 中 的 数据 


力 关键 技术 


应 用 ADODB 操 作 Access 数据库 最 简单 的 方法 就 是 应 用 实例 538 和 实例 539 中 定义 的 ADODB 连接 和 操作 数据 库 类 。 
本 实例 的 目的 是 使 读者 更 深刻 地 理解 ADODB 操作 Access 数据 库 的 方法 和 步骤 。 

(1) 载 入 adodb.inc.php 文件 ， 这 是 应 用 ADODB 类 库 操作 任何 数据 库 的 前 提 。 

(2) 连接 Access 数据 库 服 务 器 ， 依 然 应 用 ADONewConnection0 函 数 ， 但 是 其 参数 值 是 Access。 

(3) 应 用 PConnect0 函 数 连 接 指 定 的 数据 库 文件 。 这 是 Access 数据 库 与 其 他 数据 库 不 同 的 地 方 ， 数据库 文 

件 的 位 置 必须 是 一 个 绝对 路 径 。 

(4) 设置 数据 库 的 编码 格式 。 

ADODB 连接 Access 数据 库 的 关键 代码 如 下 : 


<?php 

include('../adodb$/adodb.inc.php"): // 载 入 (include) adodb.inc.php 文件 

Sconn = ADONewConnection('access’): // 连 接 Access 数据 库 

Sconn-> PConnect("Driver={Microsoft Access Driver (*.mdb)}:Dbq=F:\AppServ\www\\imr\13\W017\\data\\db database13.mdb"): 
S$conn -> execute('set names gb2312): /设置 编码 格式 


> 
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(5) 根据 连接 数据 库 成 功 返 回 的 对 象 执行 查询 语句 完成 数据 的 分 页 输出 ， 有 关 数 据 的 分 页 输出 方法 请 读者 
参考 实例 540 和 实例 341， 这 里 不 再 袭 述 。 
图 设计 过 程 

(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 。 连 接 Access 数据 库 ， 其 代码 请 参考 关键 技术 中 的 内 容 。 


(2) 创建 index.php 文件 。 首 先 包含 数 据 库 连 接 文件 ， 载 入 tohtmlinc.php 文件 。 然 后 定义 SQL 语句 ， 定 
义 分 页 变量 。 最 后 应 用 分 页 函数 完成 数据 的 分 页 输出 ， 其 关键 代码 如 下 : 


<?php 
include("conn/conn.php"); // 载 入 数据 库 连 接 文件 
include('../adodbS/tohtml ine.php'); // 载 入 tohtmline.php 文件 
$sql = 'select + from tb_bookinfo'; // 查 询 语句 
Snum =10; // 每 页 显示 的 记录 数 
iflisset($_GET['n_page'D)){ // 判 断 当前 页 码 

$c_ page =$_ GET[n page]; // 将 Sn_page 赋 给 变量 $c_page 
}else{ 

Sc page=1; // 初 始 化 变量 $c_page 


} 
S$rst= $conn -> PageExecute($sql,Snum,$c_page); /执行 pagesExecute0 函 数 
rs2html($rst,"width=810 bordercolor=#FFFFFF ",array(' 图 书 名 称 ', 出 版 社 ', 页 码 " 价 格 ', 出 版 时 间 ',ID)); 
?> 
<table width="520" height="24" border="0" cellpadding="0" cellspacing="0" bordercolor="#FFFFFF" bgcolor="#999999"> 
<tr> 
<td><font color=#999999> 当 前 是 第 <?php echo $rst -> absolutePage(); ?> 页 /一 共 是 <?php echo $rst -> LastPageNo(); ?> 页 </font></td> 
<td align="center" bgeolor="#FFFFFF"> 
<2php 
这 false ! 一 Srst){ 
if(!$rst -> AtfirstPageO){ /如 果 当 前 页 不 是 首页 
?> 
<!-- 输出 向 上 翻 页 超 链接 --> 
<a href="<?php echo In_pge=1'?>"> 首页 </a> 
<a href ="<?php echo ?n_page='(Srst -> absolutePage0 - 1); ?>"> 上 一 页 </a> 
> 


TE 


<?php 
这 LSrst -> AtlastPageO){ // 如 果 当前 页 不 是 尾 页 


?> 
<!-- 输出 向 下 翻 页 超 链接 --> 
<a href = "<?php echo 7n_page=.($rst -> absolutePage0 + 1); ?>"> 下 一 页 </a> 
<a href ="<?php echo "7n_page=.($rst -> LastPageNo():?>"> 尾 页 </a> 
,Ee 
< 2 
} 
} 


?> 
国 秘笈 心 法 
心 法 领悟 554: ADODB 操作 Access 数据 库 必须 注意 的 问题 。 
在 连接 数据 库 时 ,指定 的 Access 数据 库 文件 的 存储 位 置 必须 是 绝对 路 径 。 另 外 ， 从 Access 数据 库 中 读 取 的 


数据 要 使 用 GB2312 编码 ， 不 能 使 用 UTF 编码 格式 。 如 果 页 面 中 使 用 的 是 UTF-8 编码 ， 那 么 可 以 在 输出 数据 时 
应 用 iconv0 函 数 对 字符 串 的 编码 格式 进行 转换 。 


MySQL 数据 库 高 级 | 


趣味 指数 : 食 人 广 三 办 | 


实例 555 


力 实例 说 明 
本 实例 介绍 应 用 ADODB 访问 MySQL 数据 库 , 并且 通过 while 语句 循环 输出 数据 库 中 的 数据 , 运行 结果 如 
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图 13.20 所 示 。 


13.20 ADODB 访问 MySQL 数据 库 


图 关键 技术 


在 本 实例 中 ， 应 用 ADONewConnection0 函 数 连接 数据 库 服 务 器 ， 应 用 PConnect0 函 数 连接 db_database13 
数据 库 ， 设 置 用 户 名 为 root， 密 码 为 111， 设 置 数据 库 编码 格式 为 UTF-8。 

通过 execute0 函 数 执行 SQL 语句 ， 在 while 循环 语句 中 ， 应 用 EOF 判断 指针 位 置 ， 应 用 fields 获取 数据 表 
中 对 应 字段 的 值 ， 应 用 MoveNext0 函 数控 制 指针 的 移动 。 

本 实例 中 应 用 的 函数 请 读者 参考 实例 538 和 实例 543 关键 技术 中 的 内 容 ， 这 里 不 再 袭 述 。 


图 设计 过 程 
(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 MySQL 数据 库 的 连接 。 


(2) 创建 index.php 文件 。 首 先 包 含 数据 库 连 接 文件 ， 然 后 定义 SQL 语句 ， 通 过 execute0 函 数 执行 SQL 
语句 ， 最 后 通过 while 循环 输出 MySQL 数据 库 中 的 数据 ， 其 关键 代码 如 下 : 


<?php 

include_once (conn/conn phpy): // 载 入 (include) adodb inc php 文件 
$sqlstr = 'select * from tb_beed'; /创建 SQL 语句 

$rst = $conn -> execute($sqlstr) or die(connect error’); /执行 SQL 语句 ， 查 询 出 id 等 于 2 的 数据 
while(!S$rst -> EOF){ /while 语句 循环 输出 结果 

?> 


<b> 
<td height="20" bgcolor="#FFFFFF"><?php echo Srst -> ficlds['id]:?></td> 
<td bgcolor="#FFFFFF"><?php echo S$rst -> fields['name']:?></td> 
<td bgcolor="#FFFFFF"><?php echo S$rst -> fields['type]:?></td> 
<td bgcolor="#FFFFFF"><?php echo Srst -> fields['dates']:?></td> 

< 


<php 
Srst -> MoveNext(): /指针 下 移 
} 
S$rst -> close0: // 关 闭 连接 
$conn -> close0: // 关 闭 数据 库 
> 
力 秘笈 心 法 


心 法 领悟 555: 选择 适合 的 ADODB 操作 数据 库 方法 。 

在 实际 的 Web 程序 开发 过 程 中 , 建议 读者 应 用 实例 538 和 实例 539 中 封装 的 ADODB 连接 和 操作 数据 库 类 
来 实现 对 数据 库 的 操作 。 因 为 这 种 方法 更 适合 对 数据 库 的 管理 、 维 护 和 更 新 ， 一 旦 出 现 更 换 数据 库 服务 器 的 问 
题 也 容易 解决 。 本 实例 中 介绍 的 单一 的 数据 库 连 接 、 操 作 方 法 存在 一 定 的 局 限 性 ， 更 适合 于 读者 在 学 习 阶 段 使 
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用 ， 以 了 解 ADODB 操作 数据 库 的 函数 和 步骤 。 


高 级 | 


实例 556 


力 实例 说 明 


本 实例 介绍 应 用 ADODB 访问 SQL Server 数 据 库 , 并 且 通 过 while 
循环 语句 输出 数据 库 中 的 数据 , 其 中 还 应 用 3ADODB_FETCH_MODE 
变量 控制 结果 集 的 存储 方式 ， 运 行 结 果 如 图 13.21 所 示 。 


| | 关键 技术 图 13.21 ADODB 访问 SQL Server 数据 库 


通过 ADODB 访问 SQL Server 数据 库 的 操作 步骤 与 实例 555 应 用 ADODB 访问 MySQL 数据 库 是 相同 的 ， 
这 里 不 再 歼 述 , 唯一 的 区 别 是 在 访问 SQL Server 数据 库 时 , 应 用 $ADODB FETCH MODE 变量 对 结果 集 的 存 取 
方式 进行 控制 。 

$ADODB_FETCH MODE 变量 决定 结果 集 以 哪 种 方式 进行 存 取 ， 有 关 该 变量 的 详细 讲解 请 参考 实例 544。 

在 通过 ADODB 连接 SQL Server 数据 库 时 还 有 一 点 需要 注意 , 即 在 通过 PConnect() 函 数 连 接 数 据 库 文件 时 ， 
对 Server 服务 器 的 设置 。 如果 SQL Server 数据 库存 储 于 本 机 中 , 那么 Server 的 参数 值 可 以 使 用 localhost。 但 是 ， 
如 果 SQL Server 数据 库存 储 在 其 他 机 器 中 ， 那 么 Server 的 参数 值 必须 是 SQL Server 的 服务 器 名 称 。 


图 设计 过 程 
(1) 创建 conn 文件 夹 ， 编写 conn php 文件 ， 完 成 与 SQL Server 数据 库 的 连接 ， 并 且 设置 以 字段 名 称 为 结 
果 集 索引 。 


(2) 编写 index.php 文件 。 首 先 包含 数 据 库 连接 文件 ， 然 后 定义 SQL 语句 ， 通 过 execute0 函 数 执行 SQL 
语句 ， 最 后 循环 输出 SQL Server 数据 库 中 的 数据 ， 其 关键 代码 如 下 : 


<2php 

include_once("conn/conn.php"): 

$sqlstr = "select * from tb_goods where addtime="2009-5-23" "; // 创 建 SQL 语句 

Srst = $conn -> execute($sqlstr) or die(connect error’); /| 执行 SQL 

while(!$rst -> EOF){ // 如 果 没 有 错误 ， 则 配合 while 循环 输出 结果 
?> 


<t> 
<td align="left" bgcolor="#FFFFFF">&nbsp:<?php echo iconv('gb2312',"utf-8",Srst -> ficlds['name']):?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $rst -> ficlds['addtime']:?></td> 
<td align="left" bgcolor="#FFFFFF">&nbsp:<?php echo $rst -> ficlds['counts]:?></td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $rst -> ficlds['price]:?></td> 

</t> 


Srst -> movenext(): /1/ 指 针 下 移 
Srst -> close0; // 关 闭 连接 


?> 


力 秘笈 心 法 


心 法 领悟 556: 了 解 ADODB 操作 数据 库 的 方法 和 步骤 。 

在 本 节 的 3 个 实例 中 ， 分 别 介绍 了 如 何 通过 ADODB 操作 Access、MySQL 和 SQL Server 数据 库 ， 其 目的 
是 让 读者 对 ADODB 中 操作 数据 库 的 方法 和 步骤 有 一 个 系统 的 了 解 ， 从 中 读者 可 以 体会 到 ， 无 论 是 操作 哪 种 数 
据 库 ， 所 使 用 的 方法 和 操作 步骤 基本 都 是 相同 的 ， 这 就 是 ADODB 类 库 的 强大 之 处 ， 这 也 就 是 笔者 建议 在 实际 
的 程序 开发 过 程 中 使 用 实例 538 和 实例 539 中 封装 的 类 来 连接 和 操作 数据 库 的 原因 。 
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Smarty 模板 


PHP 开发 实例 大 全 (基础 卷 ) 
14.1 环境 搭建 


高 级 


| 
| 
起 呆 术 二 刘 窑 


力 实例 说 明 

PHP 没有 内 置 Smarty 模板 类 ， 需 要 单独 下 载 和 配置 ， 并 且 Smarty 要 求 服务 器 上 的 PHP 版 本 最 低 为 4.0.6。 
用 户 可 以 去 网 站 http://www.smarty.net/download.php 下 载 最 新 的 Smarty 压缩 包 。 本 书 使 用 的 版 本 是 Smarty 2.6.23， 
下 载 页面 如 图 14.1 所 示 。 


MD Ba Ew KR IAD NPD 
@-© 国 曾 O|P 浆 © BB 


ET aovrlast pi 


Download 


Note: The smarty Template Engne reqHres PF Versian 4.0.6 or later 


es Latest Stable Release 
Use EY Smarty 2.6.25 Ltar gz) C20) May 23rd, 2000 
Scrap Cpurse 本 
站 Previous Releases 
Tessmonials 


«Smarty 2.6.24 Ltac.g2) (ain) Ma 
Get Help Et i- 


Quick Install 


Mf my se do don oud Wordown oul leo 2 0.24 sip ET 


图 14.1 Smarty 模板 下 载 页 面 


力 关键 技术 


Smarty 模块 的 安装 步骤 : 
(1) 将 下 载 的 Smarty 压缩 包 解压 ,解压 后 的 文件 夹 如 图 14.2 所 示 , 其 中 有 一 个 libs 文件 夹 , 它 包含 了 Smarty 
类 库 的 4 个 核心 文件 : Smarty.class.php、Smarty_Compiler.class.php、Config_File.class.php 和 debug.tpl, 以 及 internals 
和 plugins 两 个 文件 夹 ， 如 图 14.3 所 示 。 


MED m2 6 E] 
文件 去 
[Ere 文件 
et ast 文件 到 
1 凶 文件 
else 四 文人 加 
opr li 24 好 LB 文件 到 国 w=oceeae asa nim BE Sle 
: 
度 1 EE 网 | 志 


图 14.3 ”Smarty-2.6.23 的 libs 文件 
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(2) Smarty 类 库 的 载 入 ， 即 将 libs 文件 夹 复制 到 服务 器 根 目录 下 并 为 其 重新 命名 。 一 般 该 目录 的 名 称 为 
smarty、class 等 ， 这 里 将 libs 文件 夹 重新 命名 为 Smarty， 并 且 复 制 到 章 文件 夹 14 下 ， 如 图 14.4 所 示 。 


ppServ\wweMERV14\VSaarty 


文件 四 查看 四。 收 遍 办。 工具 四 相助 吕 
地 址 四 ) [WpServ\ wr TEREST 


加 config File. class php 

加 aabug tpl 

加 surty class php 

辐 sasrty_ compiler class php 


图 14.4 存储 在 Apache 服务 器 下 MR\14 文件 夹 下 的 Smarty 类 库 

图 设计 过 程 

(1) 登录 http://www.smarty.net/download.php 下 载 最 新 的 
Smarty 压缩 包 。 a 6 站 

(2) 对 下 载 的 压缩 包 进行 解压 ， 将 其 中 的 libs 文件 夹 复 。 、 呈 吕 - SS 
制 到 章 文件 夹 14 中 。 | | = 

(3) 对 libs 文 件 夹 进行 重新 命名 完成 Smarty 模板 的 安装 。 
Smarty 类 库 在 本 章 实例 中 的 存储 位 置 如 图 14.5 所 示 。 图 14.5 Smarty 类 库 在 本 章 实例 中 的 存储 位 置 


国 秘笈 心 ; 
心 法 领悟 557: 运行 本 章 实例 的 前 提 条 件 。 
运行 本 章 实例 的 前 提 条 件 是 必须 要 加 载 Smarty 类 库 ， 并 且 要 将 Smarty 类 库 放置 在 实例 的 上 级 目录 〈 即 14 


文件 夹 下 ) ， 和 否则 在 运行 本 章 的 实例 时 将 会 出 现 错误 。 读 者 可 以 按照 本 实例 讲解 的 步骤 放置 Smarty 类 库 。 由 于 
Smarty 模板 属于 第 三 方 的 组 件 ， 所 以 在 光盘 中 没有 提供 ， 必 须 由 读者 自己 下 载 。 


二 : 高 级 | 


力 实例 说 明 


俗语 说 : 巧 妇 难为 无 米 之 炊 。 如 果 把 Smarty 模板 引擎 的 下 载 和 安装 比 作 “ 米 ”， 那 么 Smarty 模板 引擎 的 
配置 就 是 “ 巧 妇 ”。 如 果 不 能 出 色 地 完成 Smarty 的 配置 工作 ， 那 么 Smarty 模板 的 应 用 就 无 从 谈 起 。 本 实例 将 
详细 讲解 Smarty 模板 引擎 的 配置 方法 ， 并 且 应 用 配置 好 的 模板 引擎 编写 一 个 实例 ， 体 会 Smarty 模板 的 特性 ， 
其 运行 结果 如 图 14.6 所 示 。 


国 关键 技术 


Smarty 模板 的 配置 步骤 : 
(1) 确定 Smarty 目录 的 位 置 。 因 为 Smarty 类 库 是 通用 的 ， 每 一 个 项 目 都 可 能 会 使 用 到 ， 所 以 将 Smarty 
存储 在 根 目录 下 。 在 本 实例 中 ， 将 Smarty 类 库 文件 存储 在 章 文件 夹 14 下 面 ， 命 名 为 Smarty。 
(2) 新 建 4 个 文件 夹 templates、templates_c、configs 和 cache。 其 中 文件 夹 templates 存储 项 目的 模板 文件 ; 
文件 夹 templates c 存储 项 目的 编译 文件 ; 文件 夹 configs 存储 项 目的 配置 文件 ; 文件 夹 cache 存储 项 目的 缓存 文 


-Smary 是 cmarty 术 板 有 健 日 录 
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件 。 这 4 个 文件 夹具 体 放置 在 什么 位 置 没有 严格 的 规定 ， 只 要 设置 路 径 正 确 即 可 。 在 本 实例 中 ， 将 创建 的 4 个 
文件 夹 存储 在 558\Smarty 文件 夹 下 。 


汪 免费 服务 热线 :400-675-1066 合 收 蕊 本 站 “ 固 设 为 首页 总 联系 我 们 


明日 论坛 


明日 编程 词典 


http://www.mrbced.com 


明日 网 络 学 院 编程 词典 在 线 最 务 


回 编程 词典 软件 


编程 词典 系列 产品 是 为 编程 爱好 者 和 各 级 程序 开发 人 员 提供 的 
起 媒体 编程 即 学 即 查 即 用 软件 ， 它 开创 了 全 新 的 学 习 和 应 用 方 
式 ， 极 大 提高 了 开发 效 率 和 学 习 效 率 ， 真 正 实现 了 轻松 学 习 ， 快 
记 开 发 。 为 有 效 解决 开发 者 的 各 种 问题 ， 明 日 开通 了 400 电 话 、 网 
站 、 社 区 、QQ、TQ 服 务 ， 提 供 从 早 8，20 一 一 晚 21，00 的 四 位 一 人 
体式 全 程 技术 支持 ， 真 正 实现 了 把 私人 编程 专家 带 回 家 的 梦想 


84978981 84978962 
ingrisoft con All Rights Reservedl 


明日 编程 词典 pada 


图 14.6 第 一 个 Smarty 程序 


(3) 创建 配置 文件 。 如 果 要 应 用 Smarty 模板 ， 那 么 就 一 定 要 包含 Smarty 类 库 和 相关 信息 。 配 置信 息 可 以 
存储 在 一 个 单独 的 文件 中 ， 在 需要 时 通过 include 语句 包含 即 可 。 配 置 文件 config.php 的 代码 如 下 : 


<2pl 
人 # ”定义 服务 器 的 绝对 路 径 。*/ 
define(BASE_ PATH',$_SERVER[DOCUMENT_ROOT]): 
上 # 定义 Smarty 模板 的 绝对 路 径 */ 
define('SMARTY_PATH'\mn\14\Smarty\); 
请 加载 Smarty 类 库 文件 。*/ 
require BASE_PATH.SMARTY_PATH.'Smarty.class.php'; 
上 # 实例 化 一 个 Smarty 对 象 */ 
$smarty = new Smarty: 

族 定义 各 个 目录 的 路 径 。 村 


$smarty->template_dir 一 ' /定义 模板 文件 的 存储 位 置 
Ssmarty->compile /Smarty/templates_c/'; // 定 义 编译 文件 的 存储 位 置 
S$smarty->config marty/configs/"; // 定 义 配置 文件 的 存储 位 置 
$smarty->cache_dir ="/Smarty/cache/"; // 定 义 缓存 文件 的 存储 位 置 


> 
图 设计 过 程 
完成 Smarty 模板 的 配置 后 ， 编 写 一 个 实例 ， 体 会 Smarty 模板 引擎 的 特性 。 

(1) 在 实例 558 文件 夹 下 创建 index.php 文件 ， 编 写 动态 PHP 代码 。 首 先 设置 页 面 的 编码 格式 ， 然 后 通过 
include 语句 包含 Smarty 的 配置 文件 ， 最 后 通过 Smarty 类 库 中 的 assign() 方 法 将 数据 赋 给 模板 变量 ， 并 且 应 用 
display 指定 模板 页 ， 其 代码 如 下 : 

< 
header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 页 面 编码 格式 
include("config.php"): // 包 含 配 置 文 件 


店 使 用 Smarty 赋值 方法 将 一 对 名 称 /方法 发 送 到 模板 中 。*/ 
$smarty->assign('title', 第 一 个 Smarty 程序 ); 


$str = file_get_contents('files/content.txt’): // 读 取 文本 文件 中 的 数据 
$smarty->assign('content iconv("gb2312","utf-8",$str)): // 将 文本 文件 中 的 数据 存储 到 模板 变量 中 
店 显示 模板 */ 

Ssmarty->display(index html'); 

> 


回 ”assign() 方 法 用 于 在 模板 被 执行 时 为 模板 变量 赋值 ， 语 法 如 下 : 


{assign var=" " value=" "} 
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参数 var 是 被 赋值 的 变量 名 ， 参 数 value 是 赋 给 变量 的 值 。 
display() 方 法 用 于 显示 模板 ， 需 要 指定 一 个 合法 的 模板 资源 的 类 型 和 路 径 ， 还 可 以 通过 第 2 个 可 选 参 
数 指定 一 个 缓存 号 ， 相 关 的 信息 可 以 查看 缓存 。 

Void display (string template [. string cache id [. string compile id]]) 

参数 template 指定 一 个 合法 的 模板 资源 的 类 型 和 路 径 ， 参 数 cache id 为 可 选 参数 ， 指 定 一 个 缓存 号 ; 参 
数 compile id 为 可 选 参数 ， 指 定编 译 号 。 编 译 号 可 以 将 一 个 模板 编译 成 不 同 的 版 本 使 用 ， 例 如 针对 不 同 的 语 
言 编 译 模板 。 编 译 号 的 另外 一 个 作用 是 ， 如 果 存 在 多 个 Stemplate dir 模板 目录 ,但 只 有 一 个 Scompile_dir 编译 
后 存档 目录 ， 这 时 可 以 为 每 一 个 Stemplate dir 模板 目录 指定 一 个 编译 号 ， 以 避免 相同 的 模板 文件 在 编译 后 互 
相 覆 盖 。 相 对 于 在 每 一 次 调用 display0 的 时 候 都 指定 编译 号 ， 也 可 以 通过 设置 Scompile_id 编译 号 属性 来 一 次 
性 设 定 。 

(2) 在 实例 558 文件 夹 下 创建 Smarty 文件 夹 ， 并 在 该 文件 夹 下 新 建 3 个 文件 夹 : templates c、configs 和 
cache。 


(3) 在 实例 558 文件 夹 下 创建 index.html 文件 作为 Smarty 的 模板 文件 ， 在 该 文件 中 输出 模板 变量 传递 的 


<title>{Stitle}</title> 
<!-- 输 出 内 容 --> 
<p> {Scontent}</p> 


至 此 ， 第 一 个 应 用 Smarty 模板 开发 的 实例 编写 完成 ， 在 设计 过 程 中 只 讲解 了 3 个 步 又， 其 实 编写 一 个 完整 
的 Smarty 模板 实例 需要 5 个 步骤 ; 
(1) 下 载 Smarty 类 库 文件 ， 并 存储 到 指定 位 置 。 
(2) 编程 Smarty 模板 的 配置 文件 。 
(3) 创建 templates、templates c、configs 和 cache 文件 夹 ， 设 置 Smarty 中 各 种 文件 的 存储 位 置 。 
(4) 创建 动态 PHP 文件 ， 编 写 PHP 代码 。 
(5) 编写 Smarty 模板 文件 ， 设 计 静 态 页 面 ， 并 且 输 出 Smarty 模板 变量 中 传递 的 数据 。 
之 所 以 在 设计 过 程 中 给 出 3 个 步骤 ， 是 因为 其 他 两 个 步骤 已 经 在 关键 技术 中 进行 了 详细 的 讲解 。 
这 是 一 个 简单 的 Smarty 模板 应 用 实例 ， 读 者 也 许 体会 不 到 Smarty 模板 引擎 的 强大 功能 及 给 程序 开发 带 来 
的 便利 ， 但 是 通过 这 个 实例 已 经 展示 出 Smarty 应 用 的 基本 原理 和 操作 流程 。 


图 秘笈 心 ; 


心 法 领悟 558: Smarty 模板 引擎 的 特性 。 

Smarty 是 一 个 使 用 PHP 编写 的 应 用 于 PHP 的 模板 引擎 ， 它 将 一 个 应 用 程序 分 成 两 部 分 : 视图 和 逻辑 控制 。 
简单 地 讲 ， 就 是 将 UI〈 用 户 界 面 ) 和 PHP code (PHP 代码 ) 分 离 。 这 样 ， 程 序 员 在 修改 程序 时 ， 不 会 影响 到 页 
面 设计 ， 而 美工 在 重新 设计 或 修改 页 面 时 ， 也 不 会 影响 程序 逻辑 。 


高 级 | 


想 呆 相 娄 3 太 二 大 页 


实例 559 


力 实例 说 明 


在 实例 558 中 讲解 的 Smarty 模板 配置 方法 有 一 个 次 端 ， 即 如 果 存 储 实例 的 文件 夹 发 生变 化 ， 那 么 就 必须 修 
改 config.php 配置 文件 中 常量 SMARTY PATH 的 值 ， 否则 将 找 不 到 Smarty 类 库 的 存储 位 置 。 例如， 将 mr 文件 
夹 修改 成 mrs 文件 夹 ， 那 么 在 运行 实例 558 时 ， 将 输出 如 图 14.7 所 示 的 错误 信息 。 
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8. 1. 59/ar/14/558/ -~ Nicrosoft Interaet 01 
文件 四 ”编辑 于 ) 查看 W) 收 豪 和 ) 工具 0) 帮助 00 
纺 址 | 乱 http://192 163. 1. 59/nr/14/558/ ell 


Warning require(E- AppServ www mrs 14 Smarty Smarty class php) 
[function require]:failed to open stream No such fle or directory n 
E:\AppServ\wwiMR\14\558\config php on ine 7 


Fatal error requireO [finction require] Failed opening required 
‘EAppServiwwwmrs 14\Smarty' Smarty class php' (inciude_path=" ;Cphp5 
‘pear) in E:\AppServiwwiMR\14\558\config.php on line 7 


BE | © 可 


图 14.7 找 不 到 指定 的 Smarty 类 库 文件 


本 实例 向 读者 介绍 另外 一 种 Smarty 模板 的 配置 方法 ， 使 用 这 种 方法 ,无 论 怎么 改变 实例 的 文件 夹 ， 都 不 会 
影响 实例 的 运行 。 


图 关键 技术 


这 里 将 Smarty 配置 方法 封装 到 类 中 ， 并 存储 到 system.smarty.inc.php 文件 中 。 首 先 包含 Smarty 类 文件 
Smarty.class.php， 然 后 定义 SmartyProject 类 ， 继 承 Smarty 父 类 ， 最 后 定义 SmartyProject0 方 法 ， 设 置 Smarty 中 
模板 文件 〈templates) 、 编 译文 件 〈templates c) 、 配 置 文 件 (configs〉 和 缓存 文件 (cache〉 的 存储 位 置 。 这 
就 是 新 的 配置 文件 system.smarty.ine.php， 其 代码 如 下 : 


<?php 
require("../Smarty/Smarty.class.php"); /调用 Smarty 文件 
class SmartyProject extends Smartyf // 定 义 类 ， 继 承 Smarty 父 类 
i /定义 方法 ， 配 置 Smarty 模板 
/指定 模板 文件 存储 在 根 目录 下 
ws es el; // 指 定编 译文 件 存储 位 置 


Sthis->config_dir = ="./system/Smarty/configs/"; 
Sthis->cache_dir ="./system/Smarty/cache/": 
} 
} 
了 


既然 已 经 将 Smarty 的 配置 方法 存储 到 一 个 类 中 ， 那 么 就 需要 对 类 进行 实例 化 ， 根 据 返回 的 对 象 名 称 调用 
Smarty 中 的 方法 ， 类 的 实例 化 操作 在 system.inc.php 文件 中 完成 ， 其 返回 对 象 名 为 $smarty， 其 代码 如 下 : 


<?php 
require("system.smarty.inc.php"); // 调 用 类 文件 
$smarty=new SmartyProject(); /执行 类 的 实例 化 操作 


?> 


通过 此 方法 配置 Smarty 模板 的 好 处 是 ， 无 论 将 程序 复制 到 哪个 服务 器 下 执行 ， 都 不 需要 更 改 服务 器 或 者 
Smarty 文件 的 绝对 路 径 ， 程 序 可 以 直接 运行 。 


.BY 技巧 : 这 种 配置 方法 中 调用 的 仍 是 存储 在 章 文件 央 14 下 的 Smarty 类 库 ， 同 时 在 这 种 方法 中 将 配置 文件 存 
储 于 实例 根 目 录 下 的 system 文件 天 中 ， 将 模板 文件 夹 〈templates) 、 编 译文 件 央 templates_c) 、 
配置 文件 天 (configs) 和 缓存 文件 夹 《cache) 存储 在 system\Smarty 目录 下 。 


图 设计 过 程 
下 面 应 用 新 的 配置 方法 对 实例 558 进行 重新 编写 ， 生 成 实例 559， 步 又 如 下 : 
(1) 在 实例 的 根 目 录 下 创建 system 文件 夹 , 存储 Smarty 的 配置 文件 system.smarty.incphp 和 实例 化 操作 文 
件 system.inc.php, 同时 创建 Smarty 文件 夹 ,最 后 在 Smarty 文件 夹 下 创建 3 个 文件 夹 templates_c、configs 和 cache。 


(2) 编写 index.php 文件 ， 重 新 载 入 Smarty 的 配置 文件 ， 即 通过 include 语句 包含 system.inc.php。 
(3) 其 他 内 容 与 实例 558 相同 ， 这 里 不 再 袭 述 。 
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为 了 让 读者 更 好 地 理解 Smarty 模板 的 配置 方法 和 文件 的 存储 位 置 ,下 面 给 出 本 实例 的 文件 夹 架 构 , 如 图 14.8 
所 示 。 


文本 文件 存储 文件 志 


图 片 文件 去 
Smarty 配 于 文件 志 


寺 闵 的 配 豆 类 文件 
直板 文件 


动态 PHP 文 件 
Smarty 奏 库 文 件 卖 


图 14.8 实例 559 的 文件 夹 架构 


国 秘笈 心 ; 

心 法 领悟 559: 确立 Smarty 类 库 文件 的 存储 位 置 。 

在 本 章 中 ， 将 Smarty 类 库 文件 存储 在 章 文件 夹 14 下 ， 本 章 中 所 有 的 实例 调用 的 都 是 这 个 Smarty 类 库 ， 并 
且 从 本 实例 开始 ， 以 后 的 实例 都 采用 本 实例 中 的 Smarty 配置 方法 ， 以 后 不 再 赣 述 。 

另外 ， 如 果 要 运行 本 章 中 的 某 个 实例 (实例 558 除外 ) ， 必 须 将 Smarty 类 库 与 实例 文件 夹 放置 于 同 级 目录 
下 ， 并 且 设 置 Smarty 类 库 的 名 称 为 Smarty。 


14.2 输出 数据 


趣味 指数 : 食 食 三 谷 


实例 560 


力 实例 说 明 


在 动态 PHP 文件 中 , 可 以 通过 SESSION 变量 的 值 判 断 当前 用 户 是 否 具有 访问 权限 , 而 在 Smarty 模板 页 中 ， 
不 可 以 使 用 SESSION 变量 , 那么 该 如 何 判断 用 户 是 否 具有 访问 权限 呢 ? 这 就 是 本 实例 将 要 讲解 的 内 容 ， 即 应 用 
让 语句 在 Smarty 模板 页 中 判断 用 户 是 否 具有 访问 权限 ， 其 运行 结果 如 图 14.9 所 示 。 


风琴 办 


图 14.9 让 语句 判断 用 户 是 否 具有 访问 权限 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


图 关键 技术 


在 模板 页 中 判断 用 户 访问 权限 的 关键 是 让 语句 和 模板 变量 的 结合 运用 。 在 让 语句 中 ， 判 断 模板 变量 的 值 是 
否 为 T， 如 果 为 T， 则 说 明 具 备 访问 权限 ; 如果 模板 变量 值 为 F， 则 说 明 不 具备 访问 权限 。 

Smarty 模板 中 的 让 与 PHP 中 的 站 大 同 小 异 。 需要 注意 的 一 点 是 ，Smarty 模板 中 的 让 必 须 以 /让 为 结束 标记 ， 
其 语法 格式 如 下 : 

全 条 件 语句 匡 


语句 1 
{elscif 条 件 语句 2} 


模板 变量 的 定义 应 用 assign0 方 法 ， 在 PHP 动态 页 中 根据 用 户 权 限 的 判断 结果 为 模板 变量 赋值 。 
图 设计 过 程 


(1) 创建 system 文件 夹 ， 封 装 Smarty 模板 的 配置 方法 ， 创 建 存储 编译 文件 、 缓 存 文件 和 配置 文件 的 文件 
夹 。 其 具体 内 容 可 以 参考 实例 559， 这 里 不 再 袭 述 。 

(2) 创建 index.php 文件 ， 包 含 Smarty 配置 文件 ， 指 定 Smarty 的 模板 页 index.html。 

(3) 创建 Smarty 模板 页 index.html， 设 计 用 户 登录 页 面 ， 添 加 用 户 登 录 的 表单 元 素 ， 并 且 将 用 户 的 登录 信 
息 提交 到 index_ok.php 文件 。 

(4) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ， 判 断 提 交 的 用 户 名 和 密码 是 否 正 确 ， 如 果 正 确 则 通 
过 display0 方 法 指定 模板 页 main.html， 并且 为 模板 变量 competence 赋值 为 T; 否则 指定 到 模板 页 main html， 为 
模板 变量 competence 赋值 为 F， 其 关键 代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=UTF-8" ); 1/ 设置 文件 编码 格式 
include("system/system.ine.php"): // 包 含 配 置 文件 


if($_POST['Submit]!="" && $_POST['user]!="" && $ orl "){ 
if($_POST['user]—"mr" && $_ POST[pass] 一 "mrsoft){ 
Ssmarty->assign("competence","T"); /为 模板 变量 赋值 
$smarty->display(main html)): 1/ 指定 模板 页 
jelse{ 
S$smarty->assign("competence","F"); 
Ssmarty->display('main.html'); 
} 
jelse{ 
echo "<script>alert( 用 户 名 和 密码 不 能 为 空 ! ); window.location href='index.php':</script>"; 


?> 
(5) 创建 main.html 模板 页 。 首 先 应 用 站 语句 对 模板 变量 的 值 进行 判断 ， 如 果 值 为 则 输出 本 页 内 容 ， 如 


果 值 为 F 则 给 出 提示 信息 ， 其 关键 代码 如 下 : 
{if $competence—"T"} 
/省 略 了 部 分 内 容 
{8 
{if Scompetence—"F"} 
<script>alert( 您 没有 权限 访问 ， 请 重新 登录 ):window ,location href="index php":</script> 
{ 刘 


力 秘笈 心 法 
心 法 领悟 560: Smarty 模板 中 让 条 件 语句 的 修饰 词 。 
Smarty 模板 中 让 条 件 语句 ， 除 了 可 以 使 用 PHP 中 的 <、>、=、!= 等 常见 运算 符 外 ,还 可 以 使 用 eq、 ne、 neq、 


gt, lt, lte、 le、gte、ge、iseven、is odd、is not even、is not odd、not、mod、div by、even by、odd by 等 修饰 词 
修饰 。 
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高 级 | 
趣味 指数 : 会 依依 家 


力 实例 说 明 


本 实例 应 用 Smarty 模板 中 的 foreach 语句 在 模板 页 中 直接 生成 一 个 数字 验证 码 ， 它 相当 于 在 动态 PHP 中 开 
发 的 验证 码 ， 但 更 加 简单 、 实 用 。Smarty 模板 中 生成 验证 码 的 运行 结果 如 图 14.10 所 示 。 


用 户 名 ; 后 一 一 验证 权 : 371999 
二 三 : owes BE ss 


图 14.10 ”Smarty 模板 中 生成 数字 验证 码 


图 关键 技术 


严格 地 说 ， 这 个 验证 码 不 是 在 Smarty 模板 页 中 生成 的 ， 只 是 通过 foreach 语句 将 PHP 动态 页 中 生成 的 验证 
码 在 模板 页 中 输出 。 因 此 本 实例 开发 的 关键 是 foreach 语句 的 应 用 和 验证 码 的 生成 。 
(1) 应 用 mt_rand0 函 数 生成 验证 码 ， 其 语法 如 下 : 
int mt_rand ( [int min, int max]) 
如 果 mt_rand0 函 数 没有 提供 可 选 参数 min 和 max， 则 返回 0~RAND_MAX 之 间 的 伪 随 机 数 。 
(2) 应 用 explode0) 函 数 将 生成 的 验证 码 写 入 数组 中 ， 其 语法 如 下 : 
array explode(string separator, string string, [int limit]) 
返回 由 字符 串 组 成 的 数组 ， 每 个 元 素 都 是 string 的 一 个 子 串 ， 它 们 被 字符 串 separator 作为 边界 点 分 隔 出 来 。 
如 果 设 置 limit 参数 ， 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 后 那个 元 素 将 包含 string 的 剩余 部 分 。 
如 果 separator 为 空 字符 串 〈"") ，explode0 函 数 将 返回 FALSE; 如 果 separator 所 包含 的 值 在 string 中 找 不 
到 ， 那 么 explode0 函 数 将 返回 包含 string 单个 元 素 的 数组 ， 如 果 参 数 limit 是 负数 ， 则 返回 除了 最 后 的 -limit 个 
元 素 外 的 所 有 元 素 。 
(3) 通过 assign0 方 法 将 验证 码 数 组 赋 给 模板 变量 。 
il foreach 语句 循环 输出 模板 变量 中 的 数组 元 素 。foreach 的 语法 如 下 : 


1 name key=key item=item from=arr name} 
ey 


参数 name 为 该 循环 的 名 称 ，key 为 当前 元 素 的 键 值 ，item 是 当前 元 素 的 变量 名 ; from 是 该 循环 的 数组 。 其 
中 ，item 和 from 是 必 选 参数 ， 不 可 省 略 。 


力 设计 过 程 
(1) 创建 system 文件 夹 ， 封 装 Smarty 模板 的 配置 方法 ， 这 里 不 再 著述 。 


a 


PHP 开发 实例 大 全 (基础 卷 ) 
(2) 创建 index.php 文件 ， 生 成 验证 码 并 且 将 验证 码 赋 给 模板 变量 ， 最 后 指定 模板 页 ， 其 代码 如 下 : 
<?php 


require_once("system/system ine.php"); // 包 含 配置 文件 

Sarray= explode( ', mt_rand(1000.9999)); /1/ 生 成 随机 验证 码 
$smarty->assign('title'"Smarty 模板 中 生成 数字 验证 码 ): // 将 指定 数据 赋 给 模板 变量 
Ssmarty->assign('content' Sarray): // 将 数组 赋 给 模板 变量 
$smarty->display(index-html); /指定 模板 页 

> 


(3) 创建 index.html 模板 文件 ， 设 计 用 户 登录 页 面 ， 添 加 用 户 登 录 的 表单 元 素 ， 同 时 应 用 foreach 语句 输 
出 模板 变量 中 传递 的 验证 码 ， 其 关键 代码 如 下 : 


<form id="forml" name="forml" method="post" action="index ok.php"> 
<input name="user" type="text" id="user" size="10" /> 
<input type="hidden" name="checks" value="{foreach key=key item=item from=$content} {$item} {/foreach}" /> 
<input name="check" type="text" size="8" /> 
<input name="pass" type="password" id="pass" size="10" /> 
<input type="image" name="imageField" src="images/Blog 03_03.jpg" /> 
<input type="image" name="imageField2" onclick="form.resetO):return false:" sre="images/Blog_03_06.jpg" /> 

</form> 

(4) 创建 index_ok.php 文件 ,获取 表单 中 提交 的 数据 , 对 用 户 登录 信息 进行 验证 。 如 果 用 户 名 和 密码 正确 ， 
则 跳 转 到 main.php 页 面 ， 否 则 跳 转 到 index.php 页 面 。 


(5) 创建 main.php 和 main.html 文件 作为 网 站 的 主页 。 
国 秘笈 心 法 


心 法 领悟 561: 验证 码 的 运用 。 
本 实例 中 ， 应 用 foreach 语句 输出 验证 码 ， 如 果 要 更 新 验证 码 的 值 ， 可 以 单 击 “ 刷 新 ”按钮 或 者 按 F5 键 ， 
同样 也 可 以 在 地 址 栏 中 重新 输入 地 址 。 


实例 562 趣味 指教 : 请 请 请 家 
实例 说 明 


在 Smarty 模板 页 中 ， 同 样 可 以 将 网 页 的 头 、 尾 和 主 文件 分 别 进行 存储 ， 从 而 达到 页 面 重 用 的 效果 ， 这 就 是 
本 实例 将 要 讲解 的 内 容 一 一 在 Smarty 模板 页 中 设计 网 页 页 面 ， 其 运行 结果 如 图 14.11 所 示 。 


FANXING mans wr ,wen /am 
hem "chesw 雪人 如 片 妆 件 天 
口 。 村 呈 玄 团 放 关外 uo 32330 = = 
更 各 联系 方式 
口 。 棚 二 站 时 让 二 外 uo 33s0 多 UN 和 
口 。 栋 题 位置 放生 处 mio 3330 = 
更 名 电子 图书 
口 。 大 eme 外 to a330 us nm 
口 。 标题 玄 轩 放 于 处 ti 2220 
口 。 标题 玄 村 放生 外 au aoa0 
口 。 机 要 位 叶 放 理 处 am aaa0 
口 。 杞 评委 放生 外 mo 3330 
共有 2 页 ， 当 商 是 第 1 页 PE FRI) 


图 14.11 Smarty 模板 中 的 页 面 设 计 
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力 关键 技术 


在 Smarty 模板 页 中 应 用 include 函数 载 入 模板 页 。include 函数 用 于 在 当前 模板 中 包含 其 他 模板 ， 当 前 模板 
中 的 变量 在 被 包含 的 模板 中 可 用 。include 函数 的 语法 如 下 : 


{include file="file name " assign=" " var=" "} 
参数 file 指定 包含 模板 文件 的 名 称 ， 为 必 选 参数 ， 参 数 assign 指定 一 个 变量 保存 包含 模板 的 输出 ;参数 var 
传递 待 包含 模板 的 本 地 参数 ， 只 在 待 包含 模板 中 有 效 。 


图 设计 过 程 
(1) 创建 system 文件 夹 ， 封 装 Smarty 模板 的 配置 方法 ， 这 里 不 再 歼 述 。 


(2) 创建 index.php 文件 ， 应 用 switch 语句 根据 超 链接 传递 的 变量 值 ， 包 含 不 同 的 PHP 脚本 文件 ， 同 时 将 
对 应 的 模板 页 名 称 赋 给 指定 的 模板 变量 ， 其 代码 如 下 : 


<?php 


require("system/system_inc.php"); // 载 入 配置 文件 
switch ($_GET['caption']){ /应 用 switeh 语句 进行 判断 
Case "reg": 
include "reg.php"; // 包 含 PHP 脚本 
$smarty->assign('admin_phtml',reg.html); // 通 过 模板 变量 指定 模板 页 
break: 
case "log": 
include "log.php"; 


Ssmarty->assign(admin_phtml',log html’); 
break; 


case "from": 
include "for.php"; 
Ssmarty->assign('admin_phtml',for.html); 
break; 


case "mes": 
include "mes.php"; 
Ssmarty->assign('admin_phtml',‘mes.html’); 
break; 


default: 
include "for.php"; 
$smarty->assign('admin_phtml',for.html); 
break: 


} 

$smarty->assign("title","Smarty 模板 中 的 页 面 设计 --".$_GET[caption]); 
S$smarty->display("index.html"); // 指 定 模板 页 
?> 


(3) 创建 index.html 模板 页 ， 应 用 include 函数 载 入 页 面 的 头 文件 〈top.html) 、 尾 文件 〈bottom.html) 和 


主 文件 ， 其 关键 代码 如 下 : 
{Stite} 
{inelude file=top html} 
{include file=$admin phtml} 
{include file=right html} 
{include file=bottom html} 


(4) 创建 include 函数 加 载 的 模板 文件 和 动态 PHP 文件 。 
图 秘笈 心 法 
心 法 领悟 562: switch 语句 的 应 用 。 
在 程序 设计 中 ， 所 有 依据 条 件 做 出 判定 的 问题 ， 都 可 以 用 让 条 件 语句 来 解决 。 不 过 ， 在 用 让 .else… 语 句 处 


理 多 个 条 件 的 判定 问题 时 ， 组 成 条 件 的 表达 式 在 每 一 个 elseif 中 都 要 计算 一 次 ， 比 较 繁琐 。 为 了 避免 计 语句 的 
宛 长 ， 提 高 程序 的 可 读 性 ， 可 以 使 用 switch 分 支 控制 语句 。switch 语句 的 语法 如 下 : 


switch(variablej{ 

case valuel: 
statement]: 
break: 


PHP 开发 实例 大 全 (基础 卷 ) 
case value2: 


default: 
default statement n: 


} 

switch 语句 根据 variable 的 值 ， 依 次 与 case 中 的 value 值 相 比较 ， 如 果 不 相 等 ， 继 续 查 找 下 一 个 case; 如 果 
相等 ,就 执行 对 应 的 语句 ,直到 switch 语句 结束 或 遇 到 break 为止, 一般 switch 语句 的 最 后 都 有 一 个 默认 值 default， 
如 果 在 前 面 的 case 中 没有 找到 相符 的 条 件 ， 则 输出 默认 语句 ， 和 else 语句 类 似 。 


力 实例 说 明 


由 于 在 Smarty 模板 中 默认 使 用 “{” 和 “}” 作 
为 定 界 符 ， 所 以 如 果 直 接 在 Smarty 模板 中 定义 CSS 六 三 [6]htts: 1/192 168.1.53/or/14/007/ 可 上 日 亲 
样式 ， 将 输出 如 图 14.12 所 示 的 错误 。 ee Smarty error [in indax.htmlline 8]: syntax i 

该 错误 出 现 的 原因 是 在 Smarty 模板 页 中 直接 将 。 | seesgieec we ei Rew Goa Copier ee Pip bas 
CSS 样式 中 使 用 的 “{” 和 “}” 解 析 为 Smarty 模板 届 辣 ne = 
的 定 界 符 ， 为 了 避免 在 Smarty 模板 中 直接 定义 CSS 。 S 
样式 时 出 现 错误 ，Smarty 提供 了 特殊 的 处 理 方法 ， 14.12 在 Smarty 模板 中 直接 定义 CSS 样式 时 出 现 的 错误 
这 就 是 本 实例 将 要 讲解 的 literal 标签 。 


图 关键 技术 


literal 标签 将 区 域内 的 数据 当 作文 本 处 理 ， 此 时 模板 将 忽略 其 内 部 的 所 有 字符 信息 。 该 特性 用 于 显示 有 可 
能 包含 大 括号 等 字符 信息 的 CSS 样式 或 者 JavaScript 脚本 ， 当 这 些 信 息 处 于 {literal} {/literal} 标签 中 时 ， 模 板 
引擎 将 不 进行 分 析 而 直接 显示 。 
图 设计 过 程 

这 里 仍然 应 用 实例 561 中 的 内 容 ， 唯 一 的 区 别 是 在 index.html 模板 页 中 ， 通 过 {literal} Uliteral} 标签 定义 一 
个 CSS 样式 ， 控 制 页 面 中 表格 、 文 字 的 背景 、 字 体 和 大 小 等 ， 其 关键 代码 如 下 : 

人 

< 一 


body,td,th { 
font-size: 12px: 


高 级 | 
起 味 指数 : 庚 负 去 家 ， 


文件 刀 铺 辑 如 查看 WW 收 康 ) 工具 CD) 和 助 WD 


I 2 
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text-decoration: none: 
} 

人 

</style> 

{/literal} 


本 实例 中 的 其 他 内 容 这 里 不 再 著述 ， 读 者 可 以 参考 实例 561。 
国 秘笈 心 法 


心 法 领悟 563: 修改 Smarty 模板 的 定 界 符 。 

在 Smarty 模板 中 ， 默 认 的 定 界 符 是 “{” 和 “}”， 为 了 避免 与 CSS 样式 或 者 JavaScript 脚本 冲突 ， 可 以 
使 用 $left_delimiter 和 $right_delimiter 结束 符 变 量 对 Smarty 模板 的 定 界 符 进行 修改 ， 将 其 修改 成 任意 格式 。 语 
法 如 下 : 


$smarty->left delimiter = < 全 
Ssmarty->right delimiter =")>"; 


高 级 
趣味 指数 : 袜 贾 宙 家 


力 实例 说 明 


由 于 Smarty 模板 总 是 尝试 对 “{” 和 “}” 进 行 解析 ， 所 以 想 要 直接 在 Smarty 模板 中 嵌入 JavaScript 脚本 ， 
就 必须 对 “{” 和 “}” 进 行 处 理 ， 前 者 已 经 介绍 了 使 用 literal 标签 对 大 括号 内 的 内 容 进 行 处 理 。 在 本 实例 中 将 
介绍 另外 一 种 方法 来 输出 Smarty 模板 中 的 定 界 符 ， 实 现在 Smarty 模板 中 直接 嵌入 JavaScript 脚本 。 本 实例 的 运 
行 结果 如 图 14.13 所 示 。 


14.13 Smarty 模板 下 载 页 面 


力 关键 技术 


在 本 实例 中 应 用 ldelim 和 rdelim 标签 输出 Smarty 模板 中 的 定 界 符 ， 即 通过 这 两 个 标签 在 Smarty 模板 中 直 
接 输出 “{” 和 “}”， 从 而 完成 在 Smarty 模板 中 直接 嵌入 JavaScript 脚本 的 操作 ， 其 关键 代码 如 下 : 


function check form() {ldelim} 
if (user.value — "){1delim} 
alert( 请 输入 用 户 名 人); 
retum false: 
{rdelim} 
{rdelim} 
‘</script> 


a 


PHP 开发 实例 大 全 基础 着) 
图 设计 过 程 


这 里 仍然 应 用 实例 561 中 的 内 容 ， 唯 一 的 区 别 是 在 index.html 模板 页 中 ,直接 定义 JavaScript 脚本 对 表单 中 
提交 的 数据 进行 判断 ， 通 过 ldelim 和 rdelim 标签 在 Smarty 模板 中 输出 “{” 和 “}”， 其 关键 代码 如 下 : 


<script language=iavascript> 


{rdelim} 
if (form.check.value =— "){ldelim} 
alert(' 请 输入 验证 码 ): 


本 实例 中 的 其 他 内 容 这 里 不 再 歼 述 ， 其 完整 代码 请 参考 本 书 光盘 。 
国 秘笈 心 ; 
心 法 领悟 564: literal 标签 与 ltelim、rdelim 标签 的 比较 。 
literal 标签 将 “{” 与 “}” 之 间 的 内 容 按 普通 的 文本 文件 来 解析 ， 控 制 的 是 内 容 ， 而 ldelim 与 rdelim 标签 


在 Smarty 模板 中 输出 “{” 与 “}”， 是 对 大 括号 本 身 进行 操作 。 在 Smarty 模板 中 完成 CSS 样式 或 者 JavaScript 
脚本 的 嵌入 操作 时 ， 笔 者 个 人 认为 还 是 使 用 literal 标签 方便 一 些 。 


趣味 指数 ; 请 良 育 家 
实例 说 明 


在 开发 程序 的 过 程 中 ， 经 常用 到 下 拉 列 表 框 ， 可 以 直接 
在 页 面 中 为 其 定义 值 ， 也 可 以 使 用 从 数据 库 中 读 取 的 数据 来 
定义 ， 但 无 论 使 用 哪 种 方法 都 必须 应 用 option 标签 ， 这 是 在 
常规 的 Web 页 面 中 为 下 拉 列 表 框 赋值 的 方法 。 

本 实例 将 介绍 通过 Smarty 模板 中 的 自 定义 函数 html_ 
options 为 下 拉 列 表 框 赋值 。 使 用 Smarty 模板 中 的 自 定义 函数 
为 下 拉 列 表 框 赋值 与 使 用 option 标签 实现 的 效果 是 相同 的 ， 
但 是 这 种 方法 更 适合 从 数据 库 中 读 取 数 据 ， 更 符合 Smarty 开 
发 模式 动静 分 离 的 原则 ， 运 行 结果 如 图 14.14 所 示 。 


图 关键 技术 


自 定义 函数 html_options 根据 给 定 的 数据 创建 选项 组 .该 RN = 
函数 可 以 指定 哪些 元 素 被 选 定 ， 要 么 指定 values 和 ouput 属 
性 ， 要 么 指定 options 替代 。 自 定义 函数 的 语法 如 下 : 


wy 


| 


图 14.14 通过 html_options 函数 为 下 拉 列 表 框 赋值 
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<select name=customer id> 


{html_options values=$cust_ids selected=$customer id output=$cust_names} 
</select> 


html_options 函数 的 参数 说 明 如 表 14.1 所 示 。 
表 14.1 html_options 函数 的 参数 说 明 
类 型 


参数 说 明 


name | string 下 拉 菜 单 名 称 ， 默 认 值 为 空 
options | associative array 包含 值 和 显示 的 关联 数组 

selected | string/array, 已 选 定 的 元 素 或 元 素数 组 

output | array 包含 下 拉 列 表 各 元 素 显示 值 的 数组 


Values arTS 包含 下 拉 列 表 各 元 素 值 的 数组 


如 果 给 定 值 是 数组 ， 将 作为 OPTGROUP 处 理 ， 且 支持 递归 。 所 有 的 输出 与 XHTML 兼容 。 

如 果 指 定 可 选 属性 name， 该 选项 列表 将 被 置 于 <select name="groupname"></selec 人 > 标签 中 ， 如 果 没 有 指定 ， 
只 产生 选项 列表 。 
图 设计 过 程 

(1) 创建 system 文件 夹 。 首 先 定义 system.smarty.inc.php 文件 ， 封 装 Smarty 的 配置 方法 以 及 ADODB 连接 
和 操作 数据 库 的 方法 。 然 后 定义 system.inc.php 文件 ， 对 Smarty 配置 类 、 数 据 库 的 连接 和 操作 类 进行 实例 化 ， 并 
返回 连接 对 象 。 最 后 创建 Smarty 文件 夹 ， 定 义 Smarty 的 编译 文件 、 配 置 文件 和 缓存 文件 的 存储 目录 。 

(2) 创建 index.php 文件 。 首 先 设置 页 面 的 编码 格式 、 载 入 配置 文件 。 然 后 生成 随机 验证 码 ， 并 且 将 随机 
验证 码 的 值 赋 给 模板 变量 。 接 着 从 数据 库 中 读 取 数据 ， 将 读 取 的 数据 存储 到 数组 中 ， 并 且 将 数组 赋 给 模板 变量 ， 
作为 下 拉 列 表 框 中 的 值 。 最 后 指定 模板 页 ， 其 代码 如 下 : 


<?php 


header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
require_once("systenm/system.inc.php"); // 包 含 配 置 文 件 

S$array= explode(' ', mt_rand(1000,9999)): // 生 成 随机 验证 码 
$smarty->assign('title','html_option 函数 向 下 拉 列 表 中 添加 列表 项 ); // 将 指定 数据 赋 给 模板 变量 
$smarty->assign('content', Sarray); // 将 数组 赋 给 模板 变量 
S$res=$conn->execute("select + from tb_bced "): /执行 select 查询 语句 
Sarray=$res->GetArray(); // 返 回 查询 结果 
Sarray_id=array(); 


Sarray_name=array(): 
for($i=0:$i<$res->RecordCountO:Si+t){ 
Sarray_id[]=$array[$i][id]: 

Sarray_name[]=$array[$i][name]: 


} 
S$smarty->assign('cust_id', $array_id); // 设 置 下 拉 列 表 框 的 值 


S$smarty->assign('cust_name', $array_name): // 设 置 列表 框 的 显示 数据 
$smarty->display(index.html): /指定 模板 页 


> 

(3) 创建 index.html 模板 页 。 首 先 创建 form 表单 ， 添 加 表单 元 素 ， 将 用 户 的 注册 信息 提交 到 index_ok.php 
文件 中 ， 其 中 ， 通 过 html_options 自 定义 函数 输出 下 拉 列 表 框 的 值 ， 通 过 foreach 语句 输出 验证 码 的 值 。 然 后 应 
用 literal 标签 在 页 面 中 直接 嵌入 CSS 样式 和 JavaScript 脚本 ， 对 用 户 提交 的 信息 进行 验证 ， 其 关键 代码 如 下 : 


<form id="form" name="form" method="post" action="index_ok.php" onsubmit="return check_form(); "> 
词典 选择 :<select name="customer" id="customer"> {html_options output=$cust_name values=$cust_id }</select> 
验证 码 : <input type="hidden" id="checks" name="checks" value="{foreach key=key item=item from=$content} {$item} {/foreach}" /> 
<input name="check" type="text" id="check" size="8" />{foreach key=key item=item from=$content} {$item} {/foreach} 
<input type="image" name="imageField3" sre="images/reg_07.jpg" /> 
<input type="image" name="imageFicld4" onclick="form.reset():return false:" sre="images/reg_09.jpg" /> 
</form> 

(4) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 将 数据 添加 到 数据 表 中 ， 其 代码 如 下 : 
<Iphp 
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header ( "Content-type: text/html; charset=UTF-8" ): // 设 置 文 件 编码 格式 
require_once("system/system. ine.php"); // 包 含 配置 文件 
这 $ POST[user]!=""&&S$ POST[pass']!=""&&$ POST['checks]!=""){ / 漳 断 用 户 名 和 密码 是 否 为 空 


S$sql="insert into tb_user(user.pass.dates.email.type)values(".$_POST['user].™,".md5($_POST['pass']).™,".date("Y-m-d").",".$_POST['email].", 
"S$ POSTTeustomeel 


Sres=$admindb->ExccSQL($sql.Sconn): /| 执行 insert 添加 语句 
if(Sres){ 

echo "<seript>alert( 用 户 注册 成 功 ! "): windowlocation href='main php':</script>"; 
Jelse{ 


echo "<script>alert(' 用 户 注册 失败 ! '); window.location href="index.php';</script>"; 


这 echo "<script>alert(' 用 户 注册 信息 不 可 为 空 ! ); window.location href="index.php':</script>"; 
} 
> 
(5) 创建 main.php 和 main.html 文件 ， 定 义 用 户 注册 成 功 后 跳 转 的 页 面 ， 代 码 请 参考 本 书 光盘 。 
| 秘笈 心 法 来 自 http: 717192.156.1.59 的 页 面 册 


心 法 领悟 565: 文件 编码 格式 设置 的 重要 性 。 

在 PHP 脚本 中 ， 如 果 没 有 对 文件 的 编码 格式 进行 设置 ， 那 么 在 
输出 Javaseript 脚本 时 ， 如 果 输 出 的 是 中 文字 符 串 , 那么 将 输出 乱码 ， , 
如 图 14.15 所 示 。 所 以 在 PHP 中 通过 header0 函 数 设置 页 面 的 编码 格 。 图 1415 在 JavaScript 脚本 中 输出 乱码 
式 还 是 十 分 必要 的 ， 其 基本 的 使 用 方法 如 下 : 


header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
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实例 566 


实例 说 明 


在 Smarty 模板 中 ， 提 供 自 定义 的 日 期 、 时间 处 理 函 数 ， 通 过 它们 可 以 得 到 不 同 格式 的 日 期 、 时 间 信 息 。 在 
本 实例 中 ， 将 应 用 Smarty 模板 中 的 日 期 、 时 间 选 择 函数 ， 设 计 一 个 日 期 、 时 间 选 择 器 ， 记 录用 户 登 录 的 时 间 ， 
其 运行 结果 如 图 14.16 所 示 。 


14.16 ”Smarty 模板 中 的 日 期 、 时 间 选 择 器 


图 关键 技术 
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在 Smarty 模板 中 ， 通 过 自 定义 函数 html select date 和 html select time 生成 日 期 、 时 间 选 择 器 。 
html select_date 函数 用 于 创建 日 期 下 拉 菜 单 ， 可 以 显示 任意 年 、 月 、 日 。html select_date 函数 的 语法 说 明 


如 表 14.2 所 示 。 
表 14.2 html_select_date 函数 的 语法 说 明 
属 性 类 型 是 否 必需 的 | 默 认 值 说 明 
year size 如 果 设 置 ， 为 标签 添加 大 小 属性 
all_extra string No null 如 果 设 置 ， 为 所 有 标签 添加 附加 属性 
day_extra 如 果 设 置 ， 为 标签 添加 附加 属性 
month extra 如 果 设 置 ， 为 标签 添加 附加 属性 
year extra 如 果 设 置 ， 为 标签 添加 附加 属性 
field_order 显示 区 域 的 顺序 
field_separator 各 区 域 间 输出 的 分 隔 字符 串 


Imonth value_format 


year Size 


月 份 值 的 strftime 表示 方法 ， 默 认为 %m 
如 果 设 置 ， 为 标签 添加 大 小 属性 


html select_time 函数 用 于 创建 时 间 下 拉 菜单 ， 可 以 显示 任意 时 、 分 、 秒 。html_ select time 函数 的 语法 说 明 


如 表 14.3 所 示 。 


表 14.3 html_select_time 函数 的 语法 说 明 


属 性 类 型 说 了 明 
prefix string 变量 名 称 前 级 
time timestamp 使 用 时 间 类 型 (data/time) 
display hours boolean 是 否 显示 小 时 
display minutes boolean 是 否 显示 分 钟 
display_seconds boolean 是 否 显示 秒 
display_meridian boolean 是 否 显示 正午 界 〈 上 午 / 下 午 ) 
use_ 24 hours boolean 是 否 使 用 24 小 时 制 
minute_interval integer 分 钟 下 拉 列 表 框 的 间隔 
Second interval integer 秒 钟 下 拉 列 表 框 的 间隔 
field array string 输出 值 到 该 值 指定 的 数组 
all extra string 如 果 设 置 ， 为 标签 添加 附加 属性 
hour extra string 如 果 设 置 ， 为 标签 添加 附加 属性 
minute_extra string 如 果 设 置 ， 为 标签 添加 附加 属性 
second extra string 如 果 设 置 ， 为 标签 添加 附加 属性 
meridian extra string 如 果 设 置 ， 为 标签 添加 附加 属性 


国 设计 过 程 


(1) 创建 system 文件 夹 。 首 先 定义 system.smarty.inc.php 文件 ， 封 装 Smarty 的 配置 方法 以 及 ADODB 连 
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接 和 操作 数据 库 的 方法 。 然 后 定义 system.inc.php 文件 ， 对 Smarty 配置 类 、 数 据 库 的 连接 和 操作 类 进行 实例 化 ， 
并 返回 连接 对 象 。 最 后 创建 Smarty 文件 夹 ， 定 义 Smarty 的 编译 文件 、 配 置 文件 和 缓存 文件 的 存储 目录 。 
(2) 创建 index.php 文件 。 首 先 设置 页 面 的 编码 格式 、 载 入 配置 文件 ， 然 后 生成 随机 验证 码 ， 并 且 将 随机 


验证 码 的 值 赋 给 模板 变量 ， 最 后 指定 index.html 模板 页 ， 其 代码 如 下 : 
<?php 


header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
require_once("systemysystem inc php"; /包含 配置 文件 

S$array= explode(' ', mt_rand(1000,9999)): /生成 随机 验证 码 
$smarty->assign('title''Smarty 模板 制作 日 期 、 时 间 选 择 器 "); // 将 指定 数据 赋 给 模板 变量 
S$smarty->assign('content ,Samray); // 将 数组 赋 给 模板 变量 
S$smarty->display('index.html'); // 指 定 模板 页 

> 


(3) 创建 index.html 模板 页 ， 设 计 用 户 登录 的 form 表单 。 其 中 ， 应 用 html_select_date 和 html select_time 
函数 生成 日 期 、 时 间 下 拉 列 表 框 ， 应 用 foreach 语句 输出 验证 码 ， 最 终 将 表单 中 的 数据 提交 到 index_ok.php 文件 
中 ， 完 成 用 户 登 录 的 操作 ， 其 关键 代码 如 下 : 


<form id="form" name="form" method="post" action="index_ok.php" onsubmit="retum check_form(); "> 
日 期 : {html_select_date} 
时 间 : {html_select_ time use_24_hours=true} 
用 户 名 : <input name="user" type="text" id="user" size="20" /> 
密码 : <input name="pass" type="password" id="pass" size="20" /> 
验证 码 : <input type="hidden" id="checks" name="checks" value="{foreach key=key itcm=item from=$content) {$item} {/foreach}" /> 
<input name="check" type="text" id="check" size="8" />{foreach key=key item=item from=$content) {Sitem} {/foreach} 
<input type="image" name="imageField3" sre="images/reg 07.ipg" /> 
<input type="image" name="imageField4" onclick="form.reset(|):return false:" sre="images/reg_09.jpg"” /> 
</form> 


(4) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 用 户 登录 信息 ， 定 义 查询 语句 验证 用 户 提交 的 用 户 名 和 密 
码 是 否 正确 ， 如 果 正 确 ， 则 根据 日 期 、 时 间 选 择 器 中 提交 的 数据 ， 更 新 用 户 注册 信息 表 中 的 最 后 登录 时 间 ， 其 


代码 如 下 : 

<?php 

header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 

require_once("system/system.ine.php"); // 包 含 配 置 文件 

if($_POST['user']!=""&é&$ POST['pass']!=""&&$ POST['checks']!=""){ 
$sql="select * from tb user where user=".$ POST[user1 "and pass=".md5($ POSTTpassT)."": 
Sres=$admindb->ExecSQL($sql.$conn); /| 执行 select 查询 语句 
Be 


POSTTDate Month1"-"S POSTTDate Day1" 
ccond]: 


$sqls=" a tb_user set login_date=".$login_date." where user=".$_POST['user'].”" and pass=".md5($_POST['pass])."" 
S$rs=$admindb->ExecSQL($sqls.$conn): // 执 行 update 更 新 语句 
echo "<script>alert( 用 户 登录 成 功 ! '); window location href='main php':</seript>"; 
Jelse{ 
echo "<script>alert(' 用 户 登录 失败 ! '); window.location href='index.php':</script>"; 


} 
yelse{ 
echo "<script>alert( 用 户 登录 信息 不 可 为 空 ! ); window.location.href='index.php';</script>"; 


} 
?> 


(5) 创建 main.php 和 main.html 文件 ， 作 为 用 户 登 录 成 功 的 跳 转 页 面 ， 其 代码 请 参考 本 书 光盘 。 
图 秘 航 心 法 

心 法 领悟 566: 获取 日 期 、 时 间 下 拉 列表 框 中 的 值 。 

在 index.html 模板 页 中 直接 应 用 {html_select_date} 和 {html_select_time use_ 24_hours=true} 定 义 日 期 、 时 间 下 
拉 列 表 框 ， 那 么 应 该 如 何 获取 下 拉 列 表 框 中 对 应 的 值 呢 ? 方法 是 在 index.html 和 index.php 编写 完成 后 ， 运 行 
index.php 文件 ， 查 看 其 源 文件 即 可 获取 日 期 、 时 间 下 拉 列 表 框 对 应 的 名 称 。 然 后 ， 就 可 以 在 表单 处 理 页 中 通过 
$_POST 方法 获取 日 期 、 时 间 的 值 。 
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趣味 指数 : 二 页 丰 容 | 


实例 567 


力 实例 说 明 


在 本 实例 中 ,综合 运用 前 面 讲解 的 方法 、 技 术 , 在 模板 页 中 直接 嵌入 CSS 样式 和 JavaScript 脚本 , 通过 foreach 
语句 输出 验证 码 ， 通 过 html_options 函数 定义 下 拉 列 表 框 的 值 ， 并 且 增加 AJAX 技术 实现 用 户 名 的 无 刷新 验证 ， 
开发 一 个 完整 的 Smarty 用 户 注册 功能 模块 其 ; 运行 结果 如 图 14.17 所 示 。 


图 14.17 Smarty 模板 中 的 用 户 注册 


图 关键 技术 


通过 AJAX 技术 实现 无 刷新 验证 整体 上 可 以 分 为 3 个 步 又 : 
(1) 在 模板 页 中 ， 通 过 script 标签 调用 指定 的 JS 文件 。 创 建 form 表单 ， 添 加 表单 元 素 ， 通 过 onBlur 事件 
调用 JavaScript 脚本 函数 ， 完 成 对 表单 元 素 值 的 判断 。 
(2) 编写 JavaScript 脚本 文件 ， 创 建 自 定义 函数 ， 应 用 AJAX 技术 完成 对 表单 元 素 值 的 验证 。 
(3) 在 模板 页 中 ， 通 过 <div> 标 签 输出 验证 结果 。 
其 中 应 用 到 的 AJAX 技术 如 下 : 
(1) 在 使 用 XMLHttpRequest 对 象 发 送 请 求 和 处 理 响 应 之 前 首先 需要 初始 化 该 对 象 , 由 于 XMLHttpRequest 
不 是 一 个 W3C 标准 ， 所 以 对 于 不 同 的 浏览 器 ， 初 始 化 的 方法 也 是 不 同 的 。 


这 里 使 用 正 浏览 器 把 XMLHttpRequest 个 ActiveX 对 象 ， 具 体 方法 如 下 : 

var http_request = new ActiveXObject("Msxml2 .XMLHTTP"): 

或 者 

var http_request = new ActiveXObject("Microsoft XMLHTTP"): 

在 上 面 的 语法 中 ，Msxml2.XMLHTTP 和 MicrosoftXMLHTTP 是 针对 正 浏览 器 的 不 同 版 本 而 进行 设置 的 。 
(2) open0 方 法 。open0 方 法 用 于 设置 进行 异步 请 求 目 标的 URL、 请 求 方法 以 及 其 他 参数 信息 ， 语 法 如 下 : 

open("method","URL"[.asyncFlag{."userName"[. "password"]]]) 

在 上 面 的 语法 中 ，method 用 于 指定 请 求 的 类 型 ， 一 般 为 GET 或 POST; URL 用 于 指定 请 求 地 址 ,可 以 使 用 
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绝对 地 址 或 者 相对 地 址 ， 并 且 可 以 传递 查询 字符 串 ;，asyncFlag 为 可 选 参数 ， 用 于 指定 请 求 方式 ， 同 步 请 求 为 
TRUE， 异 步 请 求 为 FALSE， 默 认 情 况 下 为 TRUE; userName 为 可 选 参 数 ， 用 于 指定 请 求 用 户 名 ， 没 有 时 可 省 
略 ，password 为 可 选 参数 ， 用 于 指定 请 求 密码 ， 没 有 时 可 省 略 。 

(3) send( 方 法 。send( 方 法 用 于 向 服务 器 发 送 请 求 。 如 果 请 求 声明 为 异步 ， 该 方法 将 立即 返回 ， 否 则 将 等 
到 接收 到 响应 为 止 ， 其 语法 如 下 : 

send(content) 

在 上 面 的 语法 中 ，content 用 于 指定 发 送 的 数据 ， 可 以 是 DOM 对 象 的 实例 、 输 入 流 或 字符 串 。 如 果 没 有 参 
数 需要 传递 ， 可 以 设置 为 NULL。 

(4) XMLHttpRequest 对 象 的 常用 属性 。XMLHttpRequest 对 象 的 常用 属性 如 表 14.4 所 示 。 


表 14.4 XMLHttpRequest 对 象 的 常用 属性 


属 性 说 了 明 

onreadystatechange 每 个 状态 改变 时 都 会 触发 这 个 事件 处 理 器 ， 通 常会 调用 一 个 JavaScript 函数 
请 求 的 状态 ， 有 以 下 5 个 取 值 : 
0= 未 初始 化 

TeadyState 
3 = 交互 中 
4= 完 成 

responseText 服务 器 的 响应 ， 表 示 为 字符 串 

responseXML 服务 器 的 响应 ， 表 示 为 XML。 这 个 对 象 可 以 解析 为 一 个 DOM 对 象 
返回 服务 器 的 HTTP 状态 码 ， 如 : 
200=" 成 功 " 

ce 202=" 请 求 被 接受 ， 但 尚未 成 功 " 
400=" 错 误 的 请 求 " 
404=" 文 件 未 找到 " 
500=" 内 部 服务 器 错误 " 

statusText 返回 HTTP 状态 码 对 应 的 文本 


(5) XMLHttpRequest 对 象 与 服务 器 交互 。XMLHttpRequest 对 象 的 最 大 用 途 就 是 不 需要 刷新 页 面 即 可 与 服 
务 器 进行 交互 。 可 以 将 AJAX 与 服务 器 的 交互 分 为 以 下 3 个 步骤 ; 
@ 初始 化 XMLHttpRequest 对 象 ， 关 键 代码 如 下 : 


var xmlHttp = false; /定义 XMLHttpRequest 对 象 

yt{ // 如 果 浏 览 器 支持 XMLHttpRequest 对 象 ， 创 建 ActiveXObject 对 象 
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP"): 

} eatch (e) { 
ty{ 


xmlHttp =new ActiveXObject("Microsoft XMLHTTP"): 
} catch (e2) {} 


i && typeof XMLHttpRequest != "undefined") { 

2 xmlHttp = new XMLHttpRequest0; 

Nee xmlHttp = false:} 

@ 设置 请 求 状态 和 返回 处 理 函 数 ， 语 法 格式 如 下 : 

xmlobjonreadystatechange=funetion names 

其 中 xmlobj 是 XMLHttpRequest 的 对 象 ，function_name 是 用 来 处 理 请 求 状态 和 返回 码 的 函数 名 〈 即 回调 
函数 ) 。 
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@ 发 送 HTTP 请 求 ， 语 法 格式 如 下 : 

xmilobj.open(send_method,url,flag): 

其 中 xmlobj 是 XMLHttpRequest 的 对 象 ，send_method 是 发 送 方 法 ， 可 以 是 GET 或 者 POST， 与 表单 中 使 
用 的 方法 相对 应 ;url 是 页 面 要 调用 的 地 址 ; fag 是 一 个 标记 ， 如 果 为 TRUE 则 表示 在 等 待 被 调用 页 面 响应 的 时 
间 内 可 以 继续 执行 页 面 代码 ， 反 之 为 FALSE。 
图 设计 过 程 

(1) 定义 Smarty 的 配置 方法 和 ADODB 连接 、 操 作 数 据 库 的 方法 ， 有 关内 容 请 参考 实例 565， 这 里 不 再 
赣 述 。 

(2) 创建 index.php 文件 。 首 先 设置 页 面 的 编码 格式 、 载 入 配置 文件 ， 然 后 生成 随机 验证 码 ， 并 且 将 随机 
验证 码 的 值 赋 给 模板 变量 ， 接 着 从 数据 库 中 读 取 数据 ， 将 读 取 的 数据 存储 到 数组 中 ， 并 且 将 数组 赋 给 模板 变量 ， 
作为 下 拉 列 表 框 中 的 值 ， 最 后 指定 模板 页 。 

(3) 创建 index.html 模板 页 。 首 先 创建 form 表单 ， 添 加 表单 元 素 ， 将 用 户 的 注册 信息 提交 到 index_ok.php 
文件 中 ， 其 中 ， 通 过 html options 自 定义 函数 输出 下 拉 列 表 框 的 值 ， 通 过 foreach 语句 输出 验证 码 的 值 ， 然 后 应 
用 literal 标签 在 页 面 中 直接 嵌入 CSS 样式 ， 最 后 通过 script 标签 载 入 JavaScript 脚本 文件 ， 对 用 户 提交 的 注册 信 
息 进行 判断 ， 其 关键 代码 如 下 : 


{literal} 

<style type="text/css"> 

body,td,th { 

font-size: 12px; 

} 

</style> 

{/literal} 

‘<script language="javascript" src="js/createxmlhttp.js"></script> 

<script language="javascript" sre="js/check_form-js"></script> 

<form id="form" name="form" method="post" action="index._ok.php" onsubmit="retun check_form(): "> 

用 户 名 :<input name="user" type="text" id="user" onBlur="javascript:chkname()" size="20" /> 

<div id="user_check"><font color="#999999"> 请 输入 用 户 名 </font></div> 

词典 选择 <select name="customer" id="customer"> {html_options output=$cust_name values=$cust_id }</select> 

验证 码 ，<input type="hidden" id="checks" name="checks" value=" {foreach key=key item=item from=$content} {$item} {/foreach}" /> 

<input name="check" type="text" id="check" size="8" />{foreach key=key item=item from=$content} {$item} {/foreach} 

</form> 

(4) 创建 js 脚本 文件 夹 。 首 先 编写 createxmlhttp.js 文件 ， 完 成 AJAX 中 XMLHttpRequest 对 象 的 初始 化 操 

作 。 然 后 编写 check_formjs 文件 ， 定 义 check_form0 方 法 对 表单 中 提交 的 数据 进行 验证 ， 定 义 shkname() 方 法 调 
用 chkname.php 文件 实现 用 户 名 的 无 刷新 验证 ， 定 义 checkregemail(emails) 方 法 验证 邮箱 地 址 的 格式 是 否 正 确 ; 


定义 checkregtel(regtel) 方 法 验证 电话 号 码 的 格式 是 否 正 确 。 其 中 chkname0) 方 法 的 语法 如 下 : 
function chkname(){ 


if(document.getElementById('user).value—""){ // 判 断 用 户 名 表单 元 素 值 是 否 为 空 
document.getElementById('user_check').innerHTML="<font color=#FF0000> 请 输入 用 户 名 ! </font>"; // 如 果 为 空 则 输出 该 内 容 
}else{ 
var user = document.getElementById('user’).value: // 否 则 获取 用 户 名 
var url = "chkname.php?user="+user: // 定 义 url 
xmihttp.open("GET",url.true): // 通 过 GET 方法 执行 
xmlhttp.onreadystatechange = finction(|){ // 回 调 函数 
这 xmlhttp readyState 一 4){ 1/ 判断 返回 值 
var msg = xmlhttp responseText: // 获 取 返 回 值 
if(msg —'1){ // 判 断 如 果 返 回 值 为 1 
document.getElementById('user_check').innerHTML="<font color=#FF0000> 用 户 名 被 占用 ! </font>"; // 则 说 明 用 户 名 被 占用 
retum false: 
jslse if(msg — '0){ // 判 断 如 果 返 回 值 为 0 


document.getElementById('user_check').innerHTML="<font color=green> 恭 喜 您 ， 可 以 注册 !</font>": /用 户 名 可 用 
Jelse{ 

document.getElementById('user_check').innerHTMIL="<font color=green>"+msg+"</font>"; /| 输出 可 用 用 户 名 
} 
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xmlhttp.send(null); /| 执行 发 送 


} 
(5) 创建 chkname.php 文件 ,根据 超 链接 中 传递 的 参数 值 判 断 提交 的 用 户 名 是 否 被 占用 , 如 果 用 户 名 可 用 ， 
则 定义 变量 $reback 的 值 为 0， 和 否则 定义 变量 Sreback 的 值 为 1， 代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 编码 格式 
require_once("system/system.inc.php"); // 包 含 配置 文件 
$sqls="select name from tb_name where name=".$_GET['user].™" "; 
Sres=$admindb->ExecSQL($sqls, $conn); /| 执行 select 查询 语句 
i(Sres){ 

Sreback ="1'; /用 户 名 被 占用 
jelsef 

Sreback = ' 05 /用 户 名 可 用 
echo S$reback; 


> 
(6) 创建 index_ok.php 文件 ， 将 表单 中 提交 的 数据 存储 到 指定 的 数据 表 中 。 
(7) 创建 main.php 和 main.html 文件 ， 编 写 用 户 注册 成 功 后 跳 转 的 页 面 。 


心 法 领悟 567: AJAX 技术 中 XMLHttpRequest 对 象 的 readyState 属性 。 
在 正 浏 览 器 中 应 用 XMLHttpRequest 对 象 的 readyState 属性 ， 可 以 书写 为 readystate， 而 在 火狐 浏览 器 下 应 


用 XMLHttpRequest 对 象 的 readyState 属性 ， 必 须 书写 为 readyState。 所 以 为 了 保证 其 在 不 同 的 浏览 器 下 都 可 以 
使 用 ， 在 输出 时 统一 使 用 readyState。 


A 后 台 管理 系统 主页 高 级 | 
实例 568 趣味 指教 : lolol 
力 实例 说 明 


在 本 实例 中 ， 开 发 一 个 后 台 管理 系统 ， 包 括 管理 员 的 登录 、 退 出 、 后 台 管 理 系统 中 各 个 模块 的 功能 展示 模 
块 ， 当 然 这 些 模块 都 只 是 简单 的 架构 ， 没 有 实现 具体 的 功能 。 因 为 开发 本 实例 的 主要 目的 是 让 读者 了 解 如 何 通 
过 Smarty 模板 构建 后 台 管理 系统 的 主页 , 而 非 某 些 具 体 功能 模块 的 开发 。 本 实例 首先 展示 后 台 管理 的 登录 模块 ， 
如 图 14.18 所 示 ， 登 录 成 功 后 将 进入 后 台 管 理 系统 的 主页 ， 如 图 14.19 所 示 。 
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图 14.18 后 台 登 录 


力 关键 技术 
后 台 管理 系统 主页 的 设计 关键 是 PHP 中 switch 语句 和 Smarty 模板 中 assign0 方 法 与 include 函数 的 完美 结合 。 


图 14.19 后台 管理 主页 
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(1) 在 模板 页 中 为 不 同 的 功能 模块 创建 超 链接 ， 并 通过 超 链 接 传递 参数 值 。 

(2) 在 动态 PHP 文件 中 ， 应 用 switch 语句 根据 超 链接 中 传递 的 参数 值 进行 判断 ， 从 而 包含 不 同 的 PHP 脚 
本 文件 ， 并 且 将 PHP 脚本 文件 对 应 的 模板 文件 名 称 通过 assign0 方 法 赋 给 指定 的 模板 变量 。 

(3) 在 模板 页 中 ， 应 用 Smarty 中 的 include 函数 加 载 模板 变量 传递 的 模板 页 。 

这 就 是 后 台 管理 系统 主页 的 设计 方法 ， 其 中 有 关 switch 语句 和 Smarty 模板 include 函数 的 详细 讲解 请 读者 
参考 本 章 实例 562， 这 里 不 再 袭 述 。 
图 设计 过 程 

(1) 创建 system 文件 夹 , 编写 Smarty 编译 、 缓存 和 配置 文件 的 存储 目录 Smarty; 编写 system.smarty.inc.php 
文件 ， 封 装 Smarty 配置 类 、ADODB 连接 和 操作 数据 库 类 ; 编写 system.inc.php 文件 ， 完 成 类 的 实例 化 操作 。 

(2) 创建 index.html 文件 ， 设 计 管理 员 登 录 页 面 ， 编写 login_ok.php 文件 ， 完 成 管理 员 的 登录 操作 。 

(3) 创建 main.php 文件 。 首 先 通过 header0 函 数 设置 页 面 的 编码 格式 ， 初 始 化 SESSION 变量 。 然 后 根据 
SESSION 变量 判断 当前 用 户 是 否 具有 访问 权限 。 接 着 ， 如 果 具 有 访问 权限 ， 则 应 用 switch 语句 根据 超 链接 传递 
的 参数 值 ， 完 成 在 不 同 页 面 之 间 的 跳 转 操作 ， 即 通过 include 函数 包含 不 同 的 动态 PHP 文件 ， 同 时 将 动态 PHP 
人 最 后 指定 模板 页 main.html， 其 代码 如 下 : 

ap) 


header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
session_start(); // 初 始 化 SESSION 变量 
if($_SESSION['user]!="" and $_SESSION['pass]!=""){ 1/ 判断 用 户 是 否 具 有 访问 权限 
require("system/system.ine.php"); // 包 含 配置 文件 
switch ($_GET[caption]){ /完成 在 不 同 模块 之 间 的 跳 转 操作 
case "商品 添加 ": 
include "sho_insert.php"; // 包 含 PHP 脚本 文件 
$smarty->assign('admin_phtml','sho_insert.html’); /将 PHP 脚本 文件 对 应 的 模板 文件 名 称 赋 给 模板 变量 
break: 
/| 省略 了 部 分 代码 
default: 
include "sho_update.php"; 
$smarty->assign('admin_phtml’,'sho_update.html); 
break; 
} 
$smarty->assign("title"," 后 台 管 理 系统 --".$_GET['caption']); // 定 义 模板 变量 


S$smarty->assign("caption",$_GET['caption']); 
Ssmarty->assign("type",$_GET['type')]): 


S$smarty->assign("dates",date("Y 年 m 月 d 日 ")); /将 当前 时 间 值 定义 到 模板 变量 中 
$smarty->assign("user",$_SESSION[user]): // 将 当前 登录 用 户 的 名 称 赋 给 模板 变量 
Ssmarty->display("main.html"): // 指 定 模板 页 


a echo "<script>alert(' 您 不 具备 访问 权限 ! "); window.location .href='index.html':</script>"; 
} 
?> 
(4) 创建 模板 页 main.html。 首 先 ， 输 出 PHP 动态 页 中 定义 的 模板 变量 值 ， 包 括 页 面 的 标题 〈$titte) 、 当 
前 时 间 ($dates) 和 当前 页 输出 的 模块 类 别 ($type、$caption) 。 然 后 , 通过 include 函数 加 载 模板 变量 $admin_phtml 
传递 的 模板 页 。 最 后 ， 为 后 台 管 理 系统 中 每 个 功能 模块 创建 热点 链接 ， 并 通过 超 链接 的 参数 传递 数据 ， 同 时 应 


用 Smarty 模板 中 的 escape 方法 对 传递 的 参数 值 进 行 编 码 ， 其 关键 代码 如 下 : 
<!-- 载 入 模板 文件 -> 
{include file=$admin_phtml} 
<!-- 创 建 热点 链接 --> 
<map name="Map" id="Map"> 
<area shape="rect" coords="29,41,88,62" href="mainphp?caption={" 商 品 添加 "|escape:"url"}&amp;type={" 商 品 管理 "|escape:"url"}" /> 
<area shape="rect" coords="30,71.91.90" hre 人 ="main.php?caption={" 商 品 修改 "|escape:"url"}&amp;type={" 商 品 管理 "|escape:"url"}" /> 
<area shape="rect" coords="31.99.91.118" href="main.php?caption={" 商 品 删除 "|escape:"url"}&amp;type={" 商 品 管理 "|escape:"url"}" /> 
</map> 


(5) 创建 热点 链接 中 链接 的 动态 PHP 文件 和 模板 文件 。 由 于 篇 幅 所 限 ， 这 里 不 对 这 部 分 内 容 进行 详细 讲 
解 ， 读 者 可 以 参考 本 书 光盘 。 
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心 法 领悟 568: Smarty 模板 中 的 URL 编码 。 
在 本 实例 中 ,通过 超 链接 传递 参数 值 时 ， 应 用 Smarty 模板 中 的 escape 方法 ， 对 超 链 接 传递 的 参数 值 进行 编 
码 ， 从 而 保护 传递 数据 的 安全 。 
A 高 级 | 
实例 i 
实例 569 趣味 指数 : A 克 克 太 | 


力 实例 说 明 


在 PHP 动态 页 中 ， 可 以 通过 while、do...while、for 和 foreach 语句 实现 数据 的 循环 输出 ， 而 在 Smarty 中 ， 
也 有 属于 自己 的 循环 输出 语句 foreach 和 section。 在 本 实例 中 介绍 通过 section 语句 完成 数据 的 循环 输出 ， 其 运 
行 结果 如 图 14.20 所 示 。 
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14.20 ”Smarty 模板 下 载 页 面 


力 关键 技术 
section 循环 语句 用 于 比较 复杂 的 数组 ， 其 语法 如 下 : 


{section name="sec_name" loop=$arr_name start=num step=num} 

参数 说 明 : 

name: 表示 循环 的 名 称 。 

loop: 表示 循环 的 数组 。 

start: 表示 循环 的 初始 位 置 ， 如 果 start=2， 那 么 说 明 循 环 从 loop 数组 的 第 2 个 元 素 开始 。 

step: 表示 步 长 ， 如 果 step=2， 那 么 循环 一 次 后 ， 数 组 的 指针 将 向 下 移动 两 位 ， 依 此 类 推 。 

section 循环 语句 读 取 的 是 存储 在 模板 变量 中 的 数组 元 素 , 而 这 个 数组 元 素 值 是 在 动态 PHP 文件 中 通过 调用 
数据 库 操作 类 中 的 Sadmindb->ExecSQL 方法 获取 的 。 

究 其 根源 就 是 应 用 ADODB 类 库 中 的 GetRows() 方 法 获取 的 查询 结果 ， 有 关 其 具体 的 设置 可 以 参考 封装 的 
数据 库 操 作 类 AdminDB， 该 类 存储 于 system\system.smarty.inc.php 文件 中 。 


图 设计 过 程 
(1) 本 实例 以 实例 568 中 开发 的 后 台 管理 系统 主页 为 基础 ， 首 先 去 除 后 台 管理 系统 的 登录 功能 ， 直 接 在 


index.php 和 index.html 中 编写 后 台 管理 系统 的 主页 ， 在 switch 语句 中 ， 将 vip_look.php 和 vip_ look html 设置 为 
默认 值 。index.php 的 关键 代码 如 下 : 
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<Iphp 

require("system/system ine.php"): 

switch ($_GET['caption]){ 

case "会 员 删 除 ": 
include "vip_delete php"; 
Ssmarty->assign('admin_phtml','vip_delete-html’); 


break; 

case "会 员 浏览 ": 
include "vip_look.php"; 
$smarty->assign('admin phtml'vip look.html"); 

break; 

1/ 省略 了 部 分 代码 

default: 

include "vip_look.php"; 

$smarty->assign('admin_phtml','vip_look.html’); 


itle"," 后 台 管理 系统 -Section 循环 输出 数据 -"S_GET[eaption]); 


{ 
$smarty->assign("caption".$_GET['caption"]); 
$smarty->assign("type".$ GETh'type"]); 
$smarty->assign("caption"," 会 员 浏 览 "); 
Ssmarty->assign("type"," 会 员 管理 "); 
ee 年 m 月 d 日 ")); 
Ssmarty->display("index.html"); 
> 
(2) 实例 568 中 没有 实际 开发 后 台 管理 系统 中 的 功能 模块 ,而 在 本 实例 中 则 对 会 员 浏览 模块 (vip_look.php 
和 vip_look.html) 进行 实际 的 开发 ， 即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 编辑 vip_look.php 文件 ， 定 义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 中 的 ExecSQL( 方 法 ， 


查询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变量 ， 其 代码 如 下 : 


<?php 

$sql="seleet * from tb_user "; // 定 义 SQL 查询 语句 
S$res=$admindb->ExecSQL($sql,$conn); /执行 查询 操作 

这 Sres){ 

$smarty->assign("res",$res); // 将 查询 结果 赋 给 指定 的 模板 变量 
} 


> 


然后 , 重新 编辑 vip look.html 文件 , 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 员 数 据 , 其 关键 代码 如 下 : 
{section name=id loop=$res} 
<t> 
<td style="padding-bottom: Spx; padding-left:Spx:; padding-right: Spx: padding-top:Spx:" align="center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom: Spx; padding-left:5px: padding-right:Spx: padding-top:5px:" align="left" bgcolor="#FFFFFF">{$res[id].user}</td> 
<td style="padding-bottom: Spx; padding-left:5px: padding-right:Spx: padding-top:5px:" align="left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:Spx: padding-right: Spx: padding-top:5px:" align="left" bgcolor="#FFFFFF">{$res[id].dates}</td> 
<t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 者 可 以 参考 实例 568， 
这 里 不 做 讲解 。 


心 法 领悟 569: section 语句 的 妙用 。 
在 本 实例 中 ， 应 用 section 语句 循环 输出 数组 中 的 所 有 元 素 值 ， 还 可 以 在 section 语句 中 添加 第 3 个 和 第 4 
个 参数 ， 即 控制 循环 的 开始 位 置 和 数组 指针 的 移动 位 置 ， 示 例 代码 如 下 : 


{section name=id loop=$res start=2 step=2} 
<tr> 
<td style="padding-bottom: Spx: padding-left:Spx: padding-right: 5px: padding-top:5px:" align="center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom: Spx: padding-left:Spx: padding-right: 5px: padding-top:5px:" align="left" bgcolor="#FFFFFF">{$res[id].user}</td> 
<td style="padding-bottom: Spx: padding-left:5px: padding-right: Spx: padding-top:5px:" align="left" bgcolor="#FFFFFF">{$res[id].email}</td> 
<td style="padding-bottom:Spx: padding-left:Spx: padding-right:Spx: padding-top:Spx:" align="left" bgcolor="#FFFFFF">{$res[id].dates}</td> 
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</tr> 
{/section} 


在 上 述 section 语句 中 ， 将 从 数组 的 第 2 个 元 素 开 始 循环 ， 并 且 数 组 指针 一 次 向 下 移动 两 位 。 
注意 ， 在 应 用 section 语句 时 ， 一 定 要 有 {/section} 结 束 标 记 。 


力 实例 说 明 


本 实例 在 应 用 section 语句 循环 输出 数据 库 中 数据 的 基础 上 ， 增 加 一 个 分 页 功能 ， 实 现 对 数据 库 中 数据 的 分 
页 显示 ， 运 行 结果 如 图 14.21 所 示 。 


明日 购物 空 各 天 仿 填 如 


接 作 
L 
县 
L 
页 % (页 上 -页 下- 页 并 


图 14.21 Smarty 模板 中 数据 的 分 页 输出 


力 关键 技术 


在 Smarty 中 实现 分 页 与 在 PHP 文件 中 实现 分 页 的 原理 是 相同 的 ， 唯 一 的 区 别 是 ， 在 Smarty 中 分 页 的 处 理 
操作 与 分 页 的 显示 是 分 离 的 。 分 页 的 处 理 操作 存储 在 sho_delete.php 文件 中 ， 其 应 用 到 的 关键 技术 如 下 : 
(1) mysql_query0 函 数 执行 查询 、 更 改 以 及 删除 等 操作 ， 语 法 如 下 : 


i 
参数 query 为 字符 串 类 型 ， 指 定 传 入 的 SQL 指令 ; 参数 link_identfier 为 资源 类 型 ， 指 定 传 入 的 由 mysql_ 
connect0 函 数 或 mysql_pconnectO 函 数 返 回 的 连接 标识 。 如 果 省 略 该 参数 ， 则 会 使 用 最 后 一 个 打开 的 MySQL 数 
据 库 连 接 。 
(2) mysql_fetch_array0 函 数 从 数组 结果 集中 获取 数据 ， 语 法 如 下 : 


array mysql_fetch_array ( resource result [. int result_type] ) 

参数 说 明 : 

result: 资源 类 型 的 参数 ， 要 传 入 的 是 由 mysql_query0 函 数 返 回 的 数据 指针 。 

result_type: 可 选项 ， 整 数 型 参数 ， 要 传 入 的 是 MYSQL ASSOC、MYSQL NUM 和 MYSQL BOTH 这 3 
种 由 PHP 定义 的 常数 之 一 ， 默 认 值 是 MYSQL BOTH 。MYSQL ASSOC 只 得 到 关联 索引 (相当 于 
mysql_fetch_assoc(0) 函 数 ) ; MYSQL NUM 只 得 到 数字 索引 (相当 于 mysql_fetch_ row0 函 数 ) ; MYSQL _ BOTH 
将 得 到 一 个 同时 包含 关联 和 数字 索引 的 数组 。 

(3) armay0 函 数 定义 一 个 数组 ， 返 回 根据 参数 建立 的 数组 。 参 数 可 以 用 “=> ”运算 符 给 出 索引 。array0 函 

数 是 一 个 语言 结构 ， 用 于 字面 上 表示 数组 ， 不 是 常规 的 函数 ， 语 法 如 下 : 

array amray ( [mixed .了 

参数 mixed 的 语法 为 key => value， 多 个 参数 间 用 逗号 分 开 ， 分 别 定义 了 索引 和 值 。 

索引 可 以 是 字符 串 或 数字 。 如 果 省 略 了 索引 ， 会 自动 产生 从 0 开始 的 整数 索引 。 如 果 索 引 是 整数 ， 则 下 一 
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个 产生 的 索引 将 是 目前 最 大 的 整数 索引 +1。 如 果 定 义 了 两 个 完全 一 样 的 索引 ， 则 后 面 一 个 会 覆盖 前 一 个 。 
(4) array_push0) 函 数 将 数组 当成 一 个 栈 ,并 将 传 入 的 变量 压 入 该 数组 的 末尾 ， 该 数组 的 长 度 将 增加 入 栈 变 
量 的 数目 ， 返 回 数组 新 的 单元 总 数 。 语 法 如 下 : 


| 

参数 说 明 : 

array: 必 选 参数 ， 输 入 的 数组 。 

var: 必 选 参数 ， 用 来 压 入 数组 的 值 。 

var2: 可 选 参数 ， 用 来 压 入 数组 的 值 。 

(5) 通过 PHP 中 的 函数 、 方 法 将 从 数据 库 中 读 取 的 数据 进行 分 页 处 理 ， 通 过 $smarty 对 象 调用 assign() 方 
法 将 分 页 处 理 返回 的 变量 传递 给 模板 变量 ， 并 通过 display0 方 法 指定 模板 页 。 

(6) 在 模板 页 sho_delete.html 中 获取 模板 变量 传递 的 值 ， 完 成 数据 的 分 页 输出 。 
图 设计 过 程 

本 实例 开发 后 台 管理 系统 中 的 商品 删除 模块 ， 其 对 应 的 操作 文件 是 sho_delete.php 和 sho_delete.html。 要 执 
行商 品 的 删除 操作 ， 首 先 必须 输出 数据 库 中 存储 的 商品 数据 ， 这 是 本 实例 的 重点 ， 再 在 Smarty 模板 中 实现 数据 
的 分 页 输出 。 

(1) 编辑 sho_delete.php 文件 ， 连 接 数 据 库 、 载 入 Smarty 配置 文件 ， 通 过 SQL 语句 读 取 数 据 库 中 的 数据 ， 


并 且 定 义 数据 的 分 页 输出 方法 ， 应 用 Smarty 中 的 assign0 方 法 将 分 页 输出 的 变量 值 传递 给 模板 页 ， 最 终 指定 模 
板 页， 其 代码 如 下 : 


Iphp 

include_once "conn/conn.php"; // 连 接 数据 库 
require_once("system/system.inc.php"); // 调 用 指定 的 配置 文件 

// 执 行 查询 语句 ， 从 数据 库 中 读 取 商品 信息 

$sql=mysql_query("select count(*) as totall from tb_bccd ",$conn); 

Sinfo=mysql_fetch_array($sql); 

$totall=$info[totall]; // 统 计数 据 库 中 数据 总 数 


这 empty($_GET[pages]) 一 true | is_numeric($_GET[pages]) 一 falsc){ // 判 断 变量 pages 是 否 为 空 
Spagel=1; // 如 果 变量 为 空 ， 则 赋值 为 1 
jelsef // 如 果 不 为 空 ， 则 获取 变量 的 值 
S$pagel=intval($_GET[pages]); 
} 
Spagesizel=3; // 定 义 每 页 显示 3 条 记录 
if($totall <$pagesizel){ // 判 断 如 果 数 据 库 中 的 数据 小 于 每 页 显示 的 记录 数 
Spagecountl=1; // 则 定义 pagecount 变量 的 值 为 1 
Jelse{ 
if($totall%$pagesizel=—0){ 
Spagecountl=intval($totall/$pagesizel): // 用 总 的 记录 数 除 以 每 页 显示 的 记录 数 ， 获 取 共 有 几 页 
Jelse{ 
Spagecountl=intval($totall/Spagesizel1)+1: 
j 
} 
// 将 要 输出 的 数据 赋 给 assign 模板 变量 


S$smarty->assign("totall",$totall); 

Ssmarty->assign("pagesizel",Spagesizel); 

Ssmarty->assign("pagel",$pagel); 

S$smarty->assign("pagecountl".$pagecount1): 

Squery=mysql_query("select * from tb_bced order by id desc limit ".($pagel1-1)*$pagesizel.”.$pagesizel",$conn ); 
Smyrow=mysql fetch_array($query): 


Sarray=array():; // 定 义 一 个 空 数组 
dof{ 
array_push($array, Smyrow); // 将 获取 的 数组 值 写 入 新 的 数组 中 

}while($myrow=mysql_fetch_array($query)): // 循 环 读 取 数据 库 中 的 数据 
这 !$array){ 

Ssmarty->assign("iscommo"."F"): // 判 断 如 果 执行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 F 
Jelse{ 

Ssmarty->assign("iscommo"."T™"); 1/ 判断 如 果 执行 成 功 ， 则 输出 模板 变量 iscommo 的 值 为 

S$smarty->assign("arr",Sarray): // 定 义 模板 变量 ar， 输 出 数据 库 中 的 数据 
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$smarty->assign(title," 商 品 删 除 "); 
?> 


(2) 编辑 sho_delete html 模板 页 ， 应 用 section 语句 和 模板 变量 完成 数据 的 分 页 输出 ， 其 关键 代码 如 下 : 
<table width="545" border="1" cellpadding="1" cellspacing="1" bordercolor="#FFFFFF" bgcolor="#3399CC"> 
<t> 
<td height="25" align="center" bgcolor="#FFFFFF">ID</td> 
<td align="center" bgcolor="#FFFFFF"> 商 品名 称 </td> 
<td align="center" bgcolor="#FFFFFF"> 操 作 </td> 
<ltr> 
{section name=id loop=$arr} 
<t> 


<td align="center" bgcolor="#FFFFFF"> {$anlid]id}</td> 

<td bgcolor="#FFFFFF">{$anlid].name}</td> 

<td align="center" bgcolor="AFFFFFF"><a href="delete. php?conn_id={$amfid].id}"> 删 除 </a></td> 
</ltr> 


<table width="545" height="25" border="0" align="center" cellpadding="0" cellspacing="0"> 

<t> 

<td> 图 书 &nbsp;{$totall}&nbsp; 本 &nbsp; 每 页 {$pagesizel} 本 &nbsp; 第 &nbsp;{$pagel}&nbsp; 页 / 共 &nbsp;{$pagecount1}&nbsp; 页 </td> 

<td align="center">{if Spagel 一 1 } 首 页 &nbsp; 上 一 页 {else}<a href="index.php?caption={$titlelescape:"url"}&pages=1"> 首 页 </a>&nbsp; 
<a href="index.php?caption= {$titlelescape:"url"} &pages={$page1-1}" > 上 一 页 </a>{/if} fifSpagel 一 Spagecountl } 下 一 页 &nbsp; 尾 页 {else} 
<a href="index.php?caption= {$titlelescape:"url"}&pages={$page1+1}"> 下 一 页 </a>&enbsp: 
<a href="index.php?caption= {$titlelescape:"url"}&pages={$pagecountl}"> 尾 页 </a>{/if} 
<htd> 


<ir> 
</table> 
(3) 商品 的 删除 通过 delete.php 文件 ， 以 超 链接 传递 的 参数 conn_id 为 条 件 ， 执 行 delete 删除 语句 ， 其 代 
码 如 下 : 
<?php 
include_once "conn/conn.php"; // 连 接 数 据 库 
require_once("system/system.inc.php"); /调用 指定 的 文件 
$sql=mysql_query("delete from tb_beed where id=".$_GET[conn id].""Sconn): /执行 删除 语句 
这 $sqD{ 
echo "<seript>alert( 数据 删除 成 功 ! '):window.location href='index.php':</script>"; 
jelsef 
i "<script>alert( 数 据 删除 失败 ! ):window.location href='index.php';</seript>"; 
} 


?> 

国 秘笈 心 法 
心 法 领悟 570: 将 mysql_fetch_array0O 函 数 返回 的 结果 在 Smarty 模板 中 输出 。 
Imysql_fetch_arrayO 函 数 返 回 的 结果 集 是 一 维 数组 ， 而 Smarty 模板 中 section 循环 语句 读 取 的 是 二 维 数组 中 


的 数据 ， 所 以 要 将 mysql fetch_array0 函 数 返回 的 结果 集 在 模板 页 中 循环 输出 ， 必 须要 将 结果 集 添加 到 一 个 数组 
中 ， 然 后 才能 应 用 section 语句 ， 其 具体 的 方法 可 以 参考 本 实例 中 的 sho_delete.php 文件 。 


完成 数据 的 分 页 显示 


实例 571 趣味 指数 : 址 全食 宙 | 


力 实例 说 明 


本 实例 将 介绍 通过 面向 对 象 的 方法 完成 Smarty 的 配置 、ADODB 连接 和 操作 MySQL 数据 库 ， 以 及 分 页 的 
功能 ， 其 运行 结果 如 图 14.22 所 示 。 
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图 14.22 ”Smarty+ADODB 完成 数据 的 分 页 显示 


图 关键 技术 


应 用 Smarty+ADODB 完成 数据 的 分 页 显示 ,涵盖 了 ADODB 连接 、 操 作 MySQL 数据 库 以 及 ADODB 中 的 
分 页 技术 , 而 Smarty 依旧 是 将 ADODB 操作 MySQL 获取 到 的 数据 通过 assign() 方 法 传递 给 模板 变量 ， 然 后 在 模 
板 页 中 应 用 section 语句 循环 输出 数据 。 

其 中 有 关 ADODB 连接 、 操 作 MySQL 数据 库 以 及 ADODB 中 分 页 技术 的 详细 讲解 ， 请 读者 参考 本 书 第 13 
章 的 内 容 ， 这 里 不 再 灼 述 。 

在 本 实例 中 ， 将 Smarty 的 配置 方法 以 及 ADODB 连接 和 操作 数据 库 的 方法 都 存储 在 system.smarty.inc.php 
文件 中 ; 将 Smarty 配置 类 、 数 据 库 的 连接 和 操作 类 的 实例 化 存储 在 system.inc.php 文件 中 ; 将 Smarty 的 编译 文 
件 、 配 置 文件 和 缓存 文件 的 存储 目录 放置 在 Smarty 文件 夹 下 ; 而 将 Smarty 类 库 和 ADODB5 类 库存 储 在 实例 根 
目录 的 同 级 目录 下 。 本 实例 的 文件 夹 架 构 如 图 14.23 所 示 。 


日 镶 站 点 -ar OF:\AppServ\re WRN14) 
Fn 实例 根 目录 
ee- 


上 传 图 片 存 鳍 文件 志 
配置 文件 存 刍 文件 夹 
Saart7 生 成 文件 存储 文件 卖 
组 存 文件 卖 


AD0DB 类 库 文件 卖 
Seurty 模 板 文件 夷 


图 14.23 本 实例 的 文件 夹 架构 
看 设计 过 程 


(1) 创建 system 文件 夹 ， 存 储 ADODB 类 库 和 Smarty 模板 文件 。 创 建 system.smarty.inc.php 文件 ， 定 义 
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数据 库 连 接 类 、 数 据 库 操作 类 和 分 页 类 。 

数据 库 连接 类 ConnDB ， 定 义 构造 方法 ConnDB 为 成 员 变 量 赋值 ， 定 义 GetConnId0 方 法 ， 应 用 
NewADOConnection0) 函 数 连接 MySQL、mssql 或 者 Access 数据 库 ， 设 置 数据 库 编 码 格式 为 UTF-8， 最 后 返回 
数据 库 连 接 对 象 ， 定 义 CloseConnId(0 方 法 ， 关 闭 与 数据 库 的 连接 。 

数据 库 操作 类 AdminDB， 定 义 ExecSQL() 方 法 完成 对 数据 库 的 添加 、 更 新 和 删除 操作 。 首 先 ， 通 过 substr() 
函数 截取 SQL 语句 中 前 6 个 字符 串 ， 并 将 截取 的 字符 串 转换 成 小 写 。 然 后 ， 通 过 Execute0 函 数 执行 SQL 语句 。 
最 后 ， 根 据 截取 的 字符 串 判断 SQL 语句 的 类 型 ， 如 果 是 select 查询 语句 ， 则 执行 GetRows0 函 数 ， 如 果 查 询 结 
果 为 0， 则 返回 FALSE， 和 否则 返回 查询 的 数组 ， 如果 SQL 语句 为 update、insert 或 者 delete 类 型 ， 执 行 成 功 则 
返回 TRUE， 和 否则 返回 FALSE。 

分 页 类 SepPage， 定 义 ShowDate() 方 法 完成 从 数据 库 中 读 取 数据 的 操作 ， 执 行 PageExecute0 函 数 实现 分 页 
功能 ， 并 且 将 返回 值 定义 到 数组 中 ， 定 义 ShowPage() 方 法 根据 查询 结果 应 用 分 页 函数 创建 分 页 超 链接 ， 并 且 将 
返回 结果 定义 到 变量 $str 中 。 

Smarty 配置 类 SmartyProject， 继 承 Smarty 类 库 中 Smarty 类 ， 设 置 本 实例 中 Smarty 缓存 文件 、 配 置 文件 、 
模板 文件 和 编译 文件 的 存储 位 置 。 

system.smarty.ine.php 文件 的 代码 请 参考 本 书 光盘 ， 由 于 篇 幅 所 限 这 里 不 再 介绍 。 

(2) 创建 system.inc.php 文件 ， 完 成 对 数据 库 连接 、 操 作 、 分 页 以 及 Smarty 配置 类 的 实例 化 操作 ， 其 代码 


如 下 : 

<?php 
require("system.smarty.ine.php"): /包含 配置 类 文件 
S$smarty=new SmartyProject(); /实例 化 配置 类 
$connobj=new ConnDB("mysql","localhost", "root"."111","db_database14",false); // 实 例 化 数据 库 连 接 类 
S$conn=$connobj->GetConnId(): 

admindb=new AdminDB(); // 实 例 化 数据 库 操作 类 
$seppage=new SepPage(); // 实 例 化 分 页 类 
> 


至 此 ， 有 关 ADODB 和 Smarty 的 安装 和 配置 方法 介绍 完毕 。 
(3) 创建 index.php 文件 ， 调 用 分 页 类 中 的 ShowDate0 方 法 ， 分 页 读 取 数 据 库 中 的 数据 ， 并 且 将 返回 值 赋 
给 模板 变量 ， 调 用 分 页 类 中 的 ShowPage0 方 法 ， 完 成 分 页 超 链接 的 输出 ， 同 样 将 返回 值 赋 给 模板 变量 ， 最 后 指 


定 模板 页 ， 其 代码 如 下 : 
<?php 


require_once("system/system.inc.php"): /包含 配置 文件 
S$arraybbs=$seppage->ShowDate("select * from tb_commo where isnew = 1 order by id ".Sconn.3.$_GET["page"]): /调用 分 页 类 ， 实 现 分 页 功能 
这 !$arraybbsj{ 


Ssmarty->assign("isbbs","F"); 

jelsef 
Ssmarty->assign("isbbs","T"): 

$smarty->assign("showpage".$seppage->ShowPage(" 商 品 "" 个 ",""."a1")): // 定 义 输出 分 页 数据 的 模板 变量 showpage 
Ssmarty->assign("arr".$arraybbs): 

和 

$smarty->assign('title''Smarty+Adodb 完成 数据 分 页 显示 )); 

Ssmarty->display('index.html'); 

2> 


(4) 创建 index.html 模板 文件 ， 应 用 section 语句 和 模板 变量 完成 数据 的 分 页 输出 。 
(5) 创建 showcommo.html 和 showcommo.php 文件 ， 用 于 输出 指定 产品 的 详细 信息 。 


力 秘笈 心 法 
心 法 领悟 571: 在 模板 页 中 谋 入 PHP 脚本 。 


在 Smarty 模板 页 中 也 可 以 嵌入 PHP 脚本 ,应 用 的 是 Smarty 中 的 PHP 标签 。PHP 标签 中 的 语句 是 否 被 处 理 
取决 于 Sphp_handling 的 设置 。 通 常情 况 下 是 不 需要 在 模板 页 中 嵌入 PHP 脚本 的 ， 但 是 不 代表 不 可 以 使 用 。 
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时 间 的 格式 化 输出 高 级 | 


趣味 指教 : 请 请 博 家 | 


odd 


实例 572 


力 实例 说 明 


在 PHP 脚本 中 ， 完 成 日 期 、 时 间 的 格式 化 输出 最 常用 的 是 date0 函 数 ， 那 么 在 Smarty 模板 中 该 如 何 完成 日 
期 、 时 间 的 输出 呢 ? 这 就 是 本 实例 要 讲解 的 内 容 ， 即 通过 Smarty 模板 中 的 date_format 函数 完成 日 期 、 时 间 的 
格式 化 输出 ， 其 运行 结果 如 图 14.24 所 示 。 
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图 14.24 Smarty 模板 中 日 期 的 格式 化 输出 


图 关键 技术 
(1) Smarty 模板 中 的 date_format 函数 用 于 格式 化 从 strftime0 函 数 获得 的 时 间 和 日 期 ， 其 应 用 示例 如 下 : 


{$smarty.nowldate_format:"%A, %B %e, %Y":Stimes} 

参数 说 明 : 

Ssmarty.now: 传递 给 date_format 的 数据 。 这 个 参数 可 以 是 在 PHP 动态 页 中 定义 的 日 期 、 时 间 模 板 变量 ， 
也 可 以 使 用 Smarty 中 的 保留 变量 $smarty.now 或 者 Smarty 模板 中 的 日 期 。 

%A, %B %e, %Y: date_format 函数 执行 格式 化 操作 时 使 用 的 格式 。 

$times: 当 传 递 给 date_format 的 数据 为 空 时 ， 通 过 $times 设置 date_format 格式 化 的 默认 值 。 

(2) date_format 函数 可 以 使 用 的 转换 格式 很 多 ， 其 常用 的 转换 格式 说 明 如 下 : 

%a - 根据 当地 格式 输出 “星期 ”的 缩写 格式 

%A - 根据 当地 格式 输出 “星期 ”的 全 称 格 式 

%b - 根据 当地 格式 输出 “月 ”的 缩写 格式 

%B - 根据 当地 格式 输出 “月 ”的 全 称 格 式 

%Y - 根据 当地 格式 输出 “年 ”的 全 称 格式 


要 了 解 date_format 函数 所 有 可 以 使 用 的 转换 格式 ， 建 议 读者 参考 Smarty 模板 的 参考 手册 。 
看 设计 过 程 

本 实例 继续 使 用 实例 571 的 内 容 ， 在 index.html 模板 文件 中 插入 date_format 函数 ， 输 出 系统 的 当前 时 间 ， 
其 关键 代码 如 下 : 

<td width="480" height="18" align="left"> 当 前 时 间 : {$smarty.nowldate format:" %A %B-%e-%Y"}</td> 

<!--{$smarty.nowldate_format} 

{$smarty.nowldate format:"%A, %B %e, %Y":S$times} 


{Ssmarty.nowldate_format:"%H:%M:9%S"} 
{Syesterdayldate_format} 
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{Syesterdayldate_format:"%A, %B %e, %Y"} 
本 实例 的 其 他 内 容 可 以 参考 实例 571， 这 里 不 再 次 述 。 
图 秘笈 心 ; 


心 法 领悟 572: date_format 函数 的 妙用 。 

通过 date_format 函数 不 但 可 以 输出 系统 的 当前 时 间 ， 如 果 配 合 strtotime0 函 数 还 可 以 获取 其 他 时 间 。 例 如 ， 
获取 系统 前 一 天 的 时 间 ， 其 方法 如 下 : 

首先 在 index.php 中 应 用 strtotimeO 函 数 获取 前 一 天 的 时 间 戳 ,并 且 将 时 间 戳 赋 给 模板 变量 然后 在 index.html 


模板 页 中 应 用 date_format 函数 格式 化 输出 前 一 天 的 时 间 ， 其 关键 代码 如 下 : 
Vindex.php 文件 
S$smarty->assign( yesterday' strtotime(-1 day’)); 
/lindex.html 文件 
{S$ yesterday date_format"%A %B - %e - %Y"} 


图 实例 说 明 


在 PHP 脚本 中 应 用 urlencode0 函 数 对 超 链接 中 传递 的 参数 进行 编码 ， 而 在 Smarty 模板 中 提供 escape 函数 
对 字符 串 进 行 编码 。 本 实例 将 详细 讲解 该 函数 的 应 用 ， 通 过 它 对 超 链 接 中 传递 的 参数 进行 编码 ， 其 运行 结果 如 
14.25 所 示 。 
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14.25 ”Smarty 模板 中 对 超 链 接 的 参数 值 进行 编码 


力 关键 技术 


escape 变量 用 于 HTML 转 码 、URL 转 码 ， 在 没有 转 码 的 变量 上 转换 单 引号 、 十 六 进 制 转 码 或 者 JavaScript 
转 码 ， 默 认 是 HTML 转 码 ， 其 基本 的 应 用 格式 如 下 : 


{$articleTitlelescape} 

{$articleTitlelescape: "html"} {* escapes & "'<>*} 

{SarticleTitlelescape:"htmlall"} {* escapes ALL html entities *} 

{SarticleTitlelescape:"url"} 

{SarticleTitlelescape:"quotes"} 

<a href="mailto: {$EmailAddresslescape:"hex"}">{$EmailAddresslescape:"hexentity"}</a> 


力 设计 过 程 
(1) 这 里 仍然 应 用 实例 568 中 的 内 容 ， 为 不 同 模块 之 间 跳 转 的 超 链接 传递 的 参数 值 编码 ， 其 具体 的 操作 在 
main html 模板 页 中 完成 ， 关 键 代码 如 下 : 
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<map name="Map" id="Map"> 


<area shape="rect" coords="29.41,88.62" href="main.php?caption={" 商 品 添加 "|escape:"url"}&amp:type={" 商 品 管理 "}" /> 
<area shape="rect" coords="30.71,91.90" href="main.php?caption={" 商 品 修改 "|escape:"url"}&amp:type={" 商 品 管理 "}" /> 
<area shape="rect" coords="31,99.91.118" href="main.php?caption={" 商 品 删 除 "|escape:"url"}&amp:type={" 商 品 管理 "}" /> 


<map> 
<map name="Map2" id="Map2"> 


<area shape="rect" coords="30.45.97.63" href="main.php?caption={" 会 员 删除 "|escape:"url"}&amp;type={" 会 员 管理 "}" /> 
<area shape="rect" coords="34.80.89.98" hre 人 "main php?caption={" 会 员 浏览 "|escape:"url"}&amp:type=f" 会 员 管理 "}" /> 


</map> 
<map name="Map5" id="Map5"> 


<area shape="rect" coords="12,11,54,36" href="logout.php" /> 


</map> 
<map name="Map6" id="Map6"> 


<area shape="rect" coords="14,12,51,36" href="main.php?caption={" 商 品 修改 "|escape:"url"}&amp;type={" 商 品 管理 "|escape:"url"}" /> 


</map> 


(2) 虽然 通过 escape 编码 后 的 模板 变量 输出 时 是 乱码 ， 但 是 在 switch 语句 中 仍然 可 以 直接 使 用 
$_GET['caption"] 获 取 超 链接 的 值 ， 根 据 这 个 值 作出 判断 ， 在 主页 中 输出 相应 模块 的 内 容 ， 不 需要 对 这 个 参数 值 


// 初 始 化 SESSION 变量 

// 判 断 用 户 名 和 密码 是 否 为 空 

// 包 含 PHP 配置 文件 

// 根 据 超 链接 传递 的 值 进 行 判断 


进行 解码 。 
执行 判断 是 在 main.php 文件 中 完成 的 ， 其 关键 代码 如 下 : 
Pn 
if($_SESSION['user]!="" and $_SESSION['pass]!=""){ 
require("system/system.inc.php"); 
switch ($_GET['caption']){ 
case "商品 添加 ": 


include "sho_insert.php"; 
$smarty->assign('‘admin_phtml','sho_insert.html"); 


break: 
/| 省略 了 部 分 代码 
default: 
include "sho_update.php"; 
$smarty->assign('admin_phtml','sho_update.html'): 
break 


} 
$smarty->assign("title"," 后 台 管理 系统 --".$_GET['caption']); 
Ssmarty->assign("caption",$_GET['caption']); 
S$smarty->assign("type"S_GET[type]): 
Ssmarty->assign("user",$_SESSION['user]): 
Ssmarty->display("main .html"); 

jelsef 


/包含 PHP 文件 
// 将 PHP 文件 对 应 的 模板 文件 的 名 称 赋 给 模板 变量 
/跳出 循环 


/为 模板 变量 赋值 

/为 模板 变量 赋值 ， 输 出 模块 名 称 
/为 模板 变量 赋值 ， 输 出 模块 所 属 类 别 
/为 模板 变量 赋值 ， 输 出 登录 用 户 名 称 
/指定 模板 页 


echo "<script>alert(' 您 不 具备 访问 权限 ! ): windowlocation href='index.html':</script>"; 


} 


好 


(3) 有 关 本 实例 中 Smarty 模板 的 配置 、 数 据 库 的 连接 和 操作 ， 以 及 用 户 登录 模块 和 子 模块 的 创建 方法 ， 


请 读者 参考 实例 568， 这 里 不 再 效 述 。 
国 秘笈 心 法 


心 法 领悟 573: escape 编码 的 重要 性 。 


传递 。 


实例 574 


四 实例 说 明 


经 过 escape 变量 编码 后 的 字符 串 在 输出 时 将 是 一 堆 乱 码 ， 在 超 链接 中 通过 这 种 方法 可 以 保证 参数 值 的 安全 


起 听 指 数 ， 砍 页 页， 


本 实例 讲解 Smarty 模板 中 正则 表达 式 的 应 用 ， 通 过 该 方法 在 Smarty 模板 页 完成 字符 串 的 蔡 换 操作 。 本 实 
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例 以 实例 569 为 基础 ， 将 分 页 输出 的 会 员 名 称 mr 蔡 换 为 明日 科技 ， 运 行 结果 如 图 14.26 所 示 。 
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图 14.26 Smarty 模板 中 正则 表达 式 的 运用 


图 关键 技术 


regex_replace 为 Smarty 模板 中 的 正则 表达 式 ， 可 对 指定 的 字符 串 进行 匹配 ， 其 包括 两 个 参数 : 第 一 个 是 指 


定 的 正则 表达 式 ， 第 二 个 是 指定 的 蔡 换 文本 ， 其 应 用 示例 如 下 : 


{Snamelregex_replace:"/[mr]/":"<font color=#FF0000> 明 日 科技 </font>"} 


在 这 个 示例 中 ， 将 模板 变量 Sname 中 的 mr 蔡 换 为 <font color=#FF0000> 明 日 科技 </font>。 


力 设计 过 程 


这 里 以 实例 570 的 内 容 为 基础 ， 对 会 员 浏览 模块 的 内 容 进 行 重新 编辑 ， 分 页 输出 会 员 浏 览 的 数据 ， 并 且 应 


用 regex_replace 变量 将 会 员 名 称 中 的 mr 蔡 换 为 明日 科技 。 


量 ， 
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(1) 编辑 vip_look.php 文件 ， 分 页 读 取 数据 库 中 存储 的 会 员 数 据 ， 并 且 将 分 页 读 取 返 回 的 变量 赋 给 模板 变 


最 终 指定 模板 页 ， 其 关键 代码 如 下 : 

<?php 

include_once "conn/conn.php"; // 连 接 数 据 库 
require_once("system/system.inc.php"); // 调 用 指定 的 文件 


/执行 查询 语句 ， 从 数据 库 中 读 取 商 品 信息 
$sql=mysql_query("select count(*) as totall from tb_name ".Sconn): 
Sinfo=mysqL_fetch_array($sqD; 


Stotall=$info[totall]; // 统 计数 据 库 中 数据 总 数 

这 empty($_GET[pages]) 一 tmue | is_numeric($_GET[pages]) 一 falsc){ // 判 断 变量 pages 是 否 为 空 
Spagel=1: // 如 果 变 量 为 空 ， 则 赋值 为 1 

Jelse{ // 如 果 不 为 空 ， 则 获取 变量 的 值 
$pagel=intval($_GET[pages]): 

} 

Spagesizel=3; // 定 义 每 页 显示 3 条 记录 

if($totall <$pagesizel){ // 判 断 如 果 数 据 库 中 的 数据 小 于 每 页 显示 的 记录 数 
$pagecount1=1; // 则 定义 pagecount 变量 的 值 为 1 

jslsef 
if($totall%$pagesize1—0){ 

S$pagecountl=intval($totall/$pagesizel): // 用 总 的 记录 数 除 以 每 页 显示 的 记录 数 ， 获 取 共有 几 页 

Jelse{ 


Spagecountl=intval($totall/Spagesizel)+1; 


} 

// 将 要 输出 的 数据 赋 给 assign 模板 变量 

Ssmarty->assign("totall".$totall): 

S$smarty->assign("pagesizel".$pagesizel): 

S$smarty->assign("pagel".$pagel): 

Ssmarty->assign("pagecount1",$pagecountl): 

$query=mysql_query("select * from tb_name order by id desc limit ".($pagel-1)*$pagesizel.". Spagesizel".$conn ): 
Smyrow=mysql_fetch_array(Squery): 

Sarray=array(): // 定 义 一 个 空 数组 
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dof 
array_push($array, Smyrow): // 将 获取 的 数组 值 写 入 新 的 数组 中 
}while($myrow=mysql_ fetch_array($query)); // 循 环 读 取 数据 库 中 数据 
这 !$array){ 
$smarty->assign("iscommo","F"); // 判 断 如 果 执行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 了 
jelsef 
$smarty->assign("iscommo","T"); // 判 断 如 果 执行 成 功 ， 则 输出 模板 变量 iscommo 的 值 为 
$smarty->assign("arr",Sarray); /定义 模板 变量 ar， 输 出 数据 库 中 数据 
} 
$smarty->assign(title," 会 员 浏 览 "); 
> 


(2) 编辑 vip look.html 模板 页 ， 通 过 section 语句 完成 会 员 信息 的 分 页 输出 ， 并 且 应 用 regex_replace 变量 
将 会 员 名 称 中 的 mr 莹 换 为 明 日 科技 ， 其 关键 代码 如 下 : 


{section name=id loop=$arr} 
<t> 
<td align="center" bgcolor="#FFFFFF"> {$anlid]id}</td> 
<td align="left" bgcolor="#FFFFFF">{$anlid].namelregex_replace:"/[mr]/":"<font color=#FF0000> 明 日 科技 </font>"}</td> 
<td align="left" bgcolor="#FFFFFF">{$an[id].email}</td> 
<td align="left" bgcolor="AFFFFFF">{$an[id].dates}</td> 


心 法 领悟 574: 通过 replace 变量 实现 字符 串 的 蔡 换 操作 。 
在 Smarty 模板 中 ， 不 但 可 以 通过 regex_replace 变量 实现 字符 串 的 蔡 换 操作 ， 还 可 以 使 用 replace 变量 完成 
字符 串 的 蔡 换 操 作 。 


ee 高 级 | 
实例 575 村 指数 : 1， 
国 实例 说 明 


在 Smarty 模板 中 ， 同 样 可 以 实现 关键 字 描 红 的 功能 ， 其 应 用 的 是 Smarty 中 的 replace 变量 。 在 本 实例 中 ， 
将 继续 应 用 后 台 管 理 系统 主页 实例 的 内 容 ， 编 辑 订 单 查询 模块 ， 实 现 对 查询 关键 字 的 描 红 功能 ， 其 运行 结果 如 
图 14.27 所 示 。 


| 


ms 后 丁 
器 订单 号 收 英 人 时 间 择 作 
1 |ol0603900781 盟 纪 科技 10-00-12 19:50.39 未 处 理 
了 aaseaane EE TO 本 
3 |0l0803300783 明 昌 科技 [2010-08-12 19:50.39 未 处 理 
|ol0605500734 明日 科技 Poloroorlz 18.51 2 已 椒 理 
5 |oto803500735 本纪 和 法 i10-08-12 19:50.39 二 处 理 
6 _|0l0803300736 明日 科 技 10-08-12 16:51-22 已 勾 理 
7 |orceo33007s7 | 明日 科技 10-08-12 19:50 39 未 处理 
§ |ol0803000739 阿 引 科技 eatlo-os-12 19:51:22 已 浆 理 


图 14.27 ”Smarty 模板 中 的 关键 字 描 红 


图 关键 技术 


(1) 在 Smarty 模板 中 ， 实 现 关键 字 描 红 功能 应 用 的 是 replace 变量 ， 该 变量 实现 字符 串 的 简单 查询 和 蔡 换 
操作 ， 包 括 两 个 参数 : 第 一 个 参数 是 被 蔡 换 的 文本 字符 串 ; 第 二 个 参数 是 用 来 蔡 换 的 文本 字符 串 ， 其 应 用 示例 
如 下 


SialeTitekeplaceanGaideanViacyaady 
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在 这 个 示例 中 ， 将 模板 变量 SarticleTitle 中 的 Garden 替换 为 Vineyard。 

(2) 查询 关键 字 描 红 的 原理 : 在 PHP 动态 页 中 获取 form 表单 提交 的 查询 关键 字 ， 并 且 执 行 模糊 查询 ， 将 
查询 结果 赋 给 模板 变量 ， 同 时 将 查询 的 关键 字 也 赋 给 模板 变量 ， 然 后 在 模板 页 中 通过 section 语句 循环 输出 查询 
结果 ， 并 应 用 replace 变量 将 查询 结果 中 关键 字 的 字体 设置 为 红色 。 

图 设计 过 程 
这 里 以 实例 570 的 内 容 为 基础 ， 对 订单 查询 模块 的 内 容 进行 重新 编辑 ， 创 建 form 表单 执行 查询 操作 ， 并 且 
应 用 replace 变量 将 查询 结果 中 的 关键 字 描 红 。 

(1) 编辑 for_select.html 模板 页 ,创建 form 表单 ， 提 交 查 询 的 关键 字 ， 将 数据 提交 到 for_select.php 页 面 进 
行 处 理 ， 同 时 在 本 页 中 应 用 section 语句 循环 输出 查询 结果 ， 并 且 应 用 replace 变量 对 查询 的 关键 字 进 行 描 红 操 
作 ， 其 关键 代码 如 下 : 

{section name=id loop=$res} 
i <td align="center" bgeolor="#FFFFFF">{$res[id]iid}</td> 
<td bgcolor="#FFFFFF">{$res[id] numberireplace:$select:"<font color=#FF0000'>$select</font>"} 
<hd> 
<td bgcolor="#FFFFFF">{Sres[id].userlreplace:" 明 日 科技 ":"<font color=#FF0000> 明 日 科技 </font>"}</td> 
<td bgcolor="#FFFFFF">{$res[id].dates}</td> 
<td align="center" bgeolor="#FFFFFF">{if$res[id].type 一 0} 未 处 理 {else} 已 处 理 {/if}</td> 


<lt> 
{/section} 


(2) 编辑 for_select.php 动态 页 ， 以 form 表单 中 提交 的 关键 字 为 条 件 执 行 模糊 查询 ， 如 果 查 询 结果 为 真 ， 
则 将 查询 结果 赋 给 模板 变量 ， 同 时 将 查询 的 关键 字 也 赋 给 指定 的 模板 变量 ， 如 果 查 询 结 果 为 FALSE， 则 为 模板 
变量 赋值 F， 其 代码 如 下 : 


<?php 

$smarty->assign(title,"Smarty 模板 中 的 关键 字 描 红 技 术 "); /定义 标题 变量 

if($_POST['number]!=""){ // 判 断 查询 关键 字 是 否 为 空 

$sql="select * from tb_order where number like %"S$_POST[mumber]"%": /定义 模糊 查询 的 语句 

$res=$admindb->ExecSQL($sql.Sconn); /执行 模糊 查询 

if(Sres){ 
$smarty->assign("select".$_POST['number’]); // 将 查询 的 关键 字 赋 给 模板 变量 
Ssmarty->assign("boo","T"); // 为 模板 变量 赋值 
Ssmarty->assign("res",$res); // 将 查询 结果 赋 给 模板 变量 

Yelse{ 

. Ssmarty->assign("boo","F"); 

} 

jelse{ 

Ssmarty->assign("boo","F"): 

因 

图 秘笈 心 法 


心 法 领悟 575: replace 变量 的 妙用 。 
通过 replace 变量 不 但 可 以 实现 查询 关键 字 描 红 的 功能 ， 而 且 可 以 实现 替换 论坛 中 的 非法 关键 字 的 功能 ， 其 
实现 方法 与 关键 字 的 描 红 是 相同 的 。 


°° 

输出 字符 囊 的 行 宽 高 级 | 
实例 576 趣味 指数 : oad 
国 实例 说 明 


在 Web 页 面 中 ， 通 常 应 用 CSS 样式 来 控制 字符 串 输 出 的 行 宽 ， 而 在 Smarty 模板 中 却 有 一 个 变量 可 以 完成 
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这 个 功能 ， 即 wordwrap。 在 本 实例 中 将 讲解 这 个 变量 的 应 用 ， 并 且 通 过 它 控制 页 面 中 输出 字符 串 的 行 宽 ， 其 运 
行 结果 如 图 14.28 所 示 。 
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图 14.28 每 行 显示 30 个 字符 串 的 运行 效果 


图 关键 技术 


wordwrap 指定 段落 的 宽度 〈 即 控制 一 行 显示 多 少 个 字符 ， 如 果 超 过 这 个 字符 数 则 换行 ) ， 其 默认 值 是 80 
字符 。 该 方法 包含 3 个 参数 : 

第 1 个 参数 设置 每 行 显示 的 字符 数 。 

第 2 个 参数 设置 在 约束 点 使 用 什么 字符 〈 默 认 值 是 换行 符 m) 。 

第 3 个 参数 控制 Smarty 是 截取 到 字符 串 的 末尾 ， 还 是 精确 到 指定 长 度 的 字符 ， 默 认 情况 是 截取 到 字符 串 的 


默认 值 ， 如 果 设 置 第 3 个 参数 的 值 为 TRUE， 那么 就 精确 截取 到 指定 长 度 的 字符 ， 其 应 用 的 示例 如 下 : 
{SarticleTitlelwordwrap:30} 


设置 段落 一 行 中 包括 30 个 字符 ， 并 使 用 \n 进行 换行 操作 。 
{SarticleTitielwordwrap:30:"<br>\n"} 


设置 段落 一 行 中 包括 30 个 字符 ， 并 使 用 <br>\n 进行 换行 操作 。 


{SarticleTitielwordwrap:30:"\n":true} 
设置 段落 一 行 中 包括 30 个 字符 ， 并 使 用 \n 进行 换行 操作 ， 同 时 精确 截取 30 个 字符 。 
上 述 示例 是 对 模板 变量 $articleTitle 中 存储 的 数据 进行 操作 。 
图 设计 过 程 
(1) 创建 system 文件 夹 。 首先 定义 system.smarty.inc.php 文件 , 封装 Smarty 的 配置 方法 。 然 后 定义 system. 
inc.php 文件 ， 对 Smarty 配置 类 进行 实例 化 ， 并 返回 连接 对 象 。 最 后 创建 Smarty 文件 夹 ， 定 义 Smarty 的 编译 文 
件 、 配 置 文件 和 缓存 文件 的 存储 目录 。 
〈2) 创建 ndex.php 文件 。 首 先 设置 页 面 的 编码 格式 、 载 入 配置 文件 。 然 后 通过 file_get_contents0 函 数 读 


取 存 储 在 文本 文件 content.txt 中 的 字符 串 ， 并 应 用 iconv0 函 数 将 字符 串 的 GB2312 编码 转换 为 UTF-8 编码 ， 同 
时 将 转换 后 的 文件 存储 到 模板 变量 中 ， 最 终 指 定 模板 页 ， 代 码 如 下 : 
<Iphp 


header ( "Content-type: text/html: charset=UTF-8" ); /设置 文件 编码 格式 
include("system/system.ine.php"); // 包 含 配置 文件 
Ssmarty->assign('title'"Smarty 模板 中 控制 输出 字符 串 的 行 宽 ): // 定 义 实例 标题 变量 

$str = file_get_contents('files/content.txt): // 读 取 文 本 文件 中 的 数据 


PHP 开发 实例 大 全 (基础 卷 ) 
S$smarty->assign('content iconv("gb2312"."utf-8",$str)): // 将 文本 文件 中 的 数据 存储 到 模板 变量 中 
Ssmarty->display(index html'); /指定 模板 页 
?> 
(3) 创建 index.html 模板 页 ， 通 过 模板 变量 输出 文本 文件 中 的 字符 串 ， 并 且 应 用 wordwrap 控制 每 行 显示 
30 个 字符 ， 应 用 <br>v 完成 换行 操作 ， 其 关键 代码 如 下 : 
{$contentlwordwrap:30:"<br>\n"} 


国 秘笈 心 法 


心 法 领悟 576: Smarty 模板 中 换行 符 的 转换 。 

在 应 用 wordwrap 控制 段落 中 每 行 显示 的 字符 时 ,默认 使 用 wn 为 换行 符 .。 但 是 使 用 wn 作为 换行 符 ， 在 页 面 中 
看 不 到 字符 串 换行 的 效果 , 只 有 在 查看 源 文 件 时 才能 看 出 字符 串 已 经 换行 , 所 以 在 应 用 wordwrap 控制 段落 中 每 行 
显示 的 字符 时 ， 应 该 设置 第 2 个 参数 ， 指 定 <br> 为 换行 符 ， 这 样 在 页 面 中 就 可 以 直接 看 到 段落 换行 的 效果 。 

在 Smarty 模板 中 ， 还 可 以 通过 nl2br0 函 数 将 所 有 的 换行 符 转 换 成 </br>， 其 使 用 方法 与 PHP 中 的 nl2br0) 函 
数 相同 ， 而 本 实例 中 的 字符 串 换 行 操作 也 可 以 使 用 如 下 方法 来 完成 : 


{Scontentlwordwrap:30|nl2br} 
S| | 
实例 Si 趣味 指数 : 例 依依 家 


力 实例 说 明 


在 PHP 中 ， 可 以 通过 function 创建 自 定义 函数 完成 一 些 特殊 的 操作 ， 同 样 在 Smarty 中 可 以 通过 
Tegister_object0 方 法 注册 对 象 , 在 模板 页 中 完成 一 些 特殊 的 操作 。 在 本 实例 中 通过 register_object0 方 法 注册 对 象 ， 
定义 方法 moneyFormatO 和 unHtml0, 分 别 对 留言 本 中 的 评分 进行 转 义 (保留 两 位 小 数 ) 及 对 留言 内 容 中 的 HTML 
标记 进行 转 义 ， 其 运行 结果 如 图 14.29 所 示 。 
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图 14.29 评分 和 HIML 标记 转 义 后 输出 


图 关键 技术 
(1) register_object0 方 法 注册 一 个 在 模板 中 使 用 的 对 象 ， 语 法 如 下 : 


void register_object (string object_name. object $object. armray allowed methods/properties. boolean format. array block methods) 


register_object 注册 对 象 的 参数 说 明 如 表 14.5 所 示 。 


f% 


第 14 章 Smarty 模板 
表 14.5 register_object 注册 对 象 的 参数 说 明 


参数 说 有明 


object_name | ”模板 页 中 使 用 的 对 象 名 称 

Sobject | 实例 化 的 对 象 名 称 

allowed methods/properties | 定义 允许 使 用 的 方法 ， 如 果 设 置 为 NULL， 表 示 所 有 方法 都 可 用 

format | ”设置 对 象 参数 传递 的 方法 ， 如 果 值 为 FALSE， 则 表示 一 次 传递 一 个 参数 


block methods 该 参数 在 format 的 值 为 TRUE 应 用 ， 向 对 象 中 添加 一 个 块 方法 


对 象 注册 成 功 后 ， 就 可 以 在 模板 页 中 通过 对 象 名 称 调用 对 象 中 的 方法 ， 完 成 对 指定 数据 的 操作 。 本 实例 在 
模板 页 中 通过 Util 对 象 分 别 调用 moneyFormat0 和 unHtml(0 方 法 ， 完 成 对 留言 本 中 评分 和 内 容 的 转 义 ， 其 关键 代 
码 如 下 : 


{if $iscommo=—"T"} 
<table width="500" border="0" align="center" cellpadding="0" cellspacing="1" bgeolor="#0099CC"> 
{section name=id loop=$array} 
<t> 
<td> {Util->unHtml pt-Sarray[id]id } 
{Util->unHtml pt=$arrayfid] title } 
评分 : {Util->moneyFormat pt=$array[id] integral} 
<br> {Util->unHtml pt=$array[id].content} 
<itd> 
</tr> 

{/section} 
</table> 
{请 

(2) str_replace0) 函 数 实现 字符 串 的 蔡 换 ， 其 语法 如 下 ， 


mixed str_replace ( mixed search mixed replace, mixed subject , int &count ) 
str_replace() 函 数 将 所 有 在 参数 subject 中 出 现 的 search 以 参数 replace 蔡 换 ， 参 数 &count 表示 蔡 换 字符 串 执 
行 的 次 数 。str_replace0 函 数 的 参数 说 明 如 表 14.6 所 示 。 


表 14.6 str_replace() 函 数 的 参数 说 明 


参数 说 了 明 
search 指定 将 要 被 葵 换 的 字符 
replace 指定 替换 所 使 用 的 字符 
subject 指定 被 操作 的 字符 串 
&count 替换 字符 串 执行 的 次 数 


(3) number_format0 函 数 将 数字 字符 串 格式 化 ， 其 语法 如 下 : 
string number_format ( float number , int decimals) 
string number_format ( float number, int decimals, string dec_point string thousands_sep) 


number_format0 函 数 返 回 参数 number 格式 化 后 的 字符 串 ， 该 函数 可 以 有 1 个 、2 个 或 者 4 个 参数 ， 但 不 能 
是 3 个 参数 。 

如 果 只 有 1 个 参数 ，number 格式 化 后 会 舍 去 小 数 点 后 的 值 ， 且 每 一 千 就 会 以 逗号 “,” 来 隔 开 。 

如 果 有 2 个 参数 ，number 格式 化 后 会 到 小 数 点 第 decimals 位 ， 且 每 一 千 就 会 以 逗号 “.” 来 隔 开 。 

如 果 有 4 个 参数 , number 格式 化 后 会 到 小 数 点 第 decimals 位 , dec_point 用 来 替代 小 数 点 “.”, thousands_sep 
用 来 替代 每 一 千 隔 开 的 逗号 “,”。 


图 设计 过 程 
(1) 创建 system 文件 夹 , 定义 Smarty 文件 夹 , 存储 编译 目录 、 缓存 目录 ; 创建 类 文件 system.smarty.inc.php， 
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定义 数据 库 连接 、 操 作 、 分 页 和 Smarty 的 配置 类 ， 定 义 类 的 实例 化 文件 system.inc.php， 完 成 各 个 类 的 实例 化 操 
作 并 返回 操作 对 象 。 
(2) 创建 ndex.php 文件 ， 包 含 类 的 实例 化 操作 文件 ， 创 建 类 ， 定 义 评分 转 义 和 html 标记 转 义 的 方法 ， 通 


过 register_object 注册 模板 对 象 ， 完 成 数据 库 中 数据 的 分 页 读 取 ， 最 终 指定 模板 页 ， 其 代码 如 下 : 
<Iphp 


require_once("system/system.ine.php"); /调用 指定 的 文件 
class Util { 
function moneyFormat($integral) { // 将 数字 转换 成 有 两 位 小 数 的 形式 
retum str_replace (", ", number format ( Sintegral, 2 ) ); 
} 
function unHtml(S$text) { // 转 换 字符 串 中 的 HTML 标签 
$str = htmlspecialchars ( $text ); 
$str = ereg_replace ( ‘<br>", \n', $str ); 
Sstr = nl2br ( $str ); 
Sstr = ereg replace ('' ‘&nbsp;", $str ); 
Teturn $str; 
t } 
Sntil=new UtilO; // 实 例 化 对 象 
Ssmarty->register_object("Util", $ntil.null,false): // 注 册 模板 对 象 
Sarray=$seppage->ShowDate("select + from tb_guestbook order by id dese",$conn.2.$_GET["page"]); /1/ 调 用 分 页 类 ， 实 现 分 页 
这 !$array){ 
$smarty->assign("iscommo","F"); // 判 断 如 果 执行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 F 
jelsef 
$smarty->assign("iscommo","T"); // 判 断 如 果 执 行 成 功 ， 则 输出 模板 变量 iscommo 的 值 为 
$smarty->assign("showpage",$seppage->ShowPage(" 留 言 "," 条 ","","a1")); // 定 义 输出 分 页 数据 的 模板 变量 showpage 
S$smarty->assign("array",Sarray); 


a 
aa 
(3) 创建 ndex.html 模板 页 ， 分 页 输出 模板 变量 中 传递 的 数据 并 且 调用 注册 模板 对 象 中 的 方法 ， 对 评分 和 
HTML 标记 进行 转换 操作 。 同 时 创建 一 个 form 表单 ， 用 于 提交 留言 信息 ， 将 数据 提交 到 index_ok.php 文件 中 。 
关键 代码 请 参考 关键 技术 中 的 内 容 。 
(4) 创建 index_ok.php 文件 ， 将 表单 中 提交 的 留言 信息 存储 到 指定 的 数据 表 中 ， 其 代码 如 下 : 


<?php 


header ( "Content-type: text/html; charset=UTF-8" ); 1/ 设置 文件 编码 格式 
require_once("systenmy/system.ine.php"): // 调 用 指定 的 文件 
Stitle=$_POST[title]: /获取 标题 
$content=$_POST[content]; /获取 内 容 
Sintegral=$_POST[integral]; 

Screatetime=date("Y-m-j H:i:s"); // 定 义 时 间 


Sarr=$admindb->ExecSQL("insert into tb_guestbook(title.content.createtime,integral) values (‘$title',Scontent',Screatetime','Sintegral)".$conn); 
这 S$arD{ 
echo "<script>alert(' 留 言 发 表 成 功 !):window.location .hre 人 index.php':</script>": 
jelsef 
echo "<script>alert( 留 言 发 表 失 败 !"):history.back0:</script>"; 
} 
> 


心 法 领悟 577: 模板 对 象 的 注销 。 
在 Smarty 模板 中 不 但 可 以 注册 模板 对 象 而 且 可 以 注销 模板 对 象 ， 注 销 模板 对 象 应 用 的 是 unregister_ objectO 
方法 。 
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实例 578 趣味 指教 : 请 良 育 家 | 


i 
J 


力 实例 说 明 


本 实例 讲解 在 Smarty 中 注册 模板 函数 的 方法 。 模 板 函 数 可 以 实现 与 PHP 中 自 定义 函数 相同 的 功能 ， 其 特 
点 是 注册 在 动态 页 中 完成 ， 实 际 的 应 用 在 静态 页 中 进行 ， 完 全 体现 Smarty 的 动静 分 离 的 开发 模式 。 本 实例 分 页 
输出 论坛 帖子 的 信息 ， 如 果 帖 子 内 容 超 出 指定 的 长 度 ， 就 通过 注册 模板 函数 对 其 进行 截取 ， 并 且 使 用 省 略 号 蔡 
代 被 截取 部 分 ， 其 运行 结果 如 图 14.30 所 示 。 
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图 14.30 ”注册 模板 函数 截取 字符 串 
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图 关键 技术 


(1) register_ function() 方 法 动态 注册 模板 函数 插件 ， 语 法 如 下 : 


void register_function (string name, mixed impl, bool cacheable, amray or null cache_attrs) 


register_function0) 方 法 的 参数 说 明 如 表 14.7 所 示 。 


表 14.7 register_function() 方 法 的 参数 说 明 


模板 函数 的 名 称 
执行 函数 的 名 称 。 执 行 函数 的 格式 可 以 是 一 个 包含 函数 名 称 的 字符 串 ; 也 可 以 是 一 个 array(&$object, 
$method) 数 组 形式 ， 其 中 &$object 是 一 个 对 象 的 引用 ， 而 $method 是 对 象 的 一 个 方法 ; 还 可 以 是 一 个 
array(&$ class. $method) 数 组 形式 ， 其 中 $class 是 一 个 类 的 名 称 ，$method 是 类 中 的 一 个 方法 

cacheable | 可 选 参数 ， 大 多 数 情 况 下 可 以 省 略 


cache attrs | 可 选 参数 ， 大 多 数 情况 下 可 以 省 略 


(2) extract0 函 数 从 数组 中 将 变量 导入 当前 的 符号 表 中 ， 语 法 如 下 : 


int extract ( array var_array [. int extract_type [. string prefix]] ) 


本 函数 用 来 将 变量 从 数组 中 导入 当前 的 符号 表 中 。 接 受 结合 数组 var_array 作为 参数 并 将 键 名 当 作 变 量 名 ， 
值 作为 变量 的 值 。 对 每 个 键 / 值 对 都 会 在 当前 的 符号 表 中 建立 变量 ， 并 受到 extract_type 和 prefix 参数 的 影响 。 

extractO 函 数 检查 每 个 键 名 是 否 可 以 作为 一 个 合法 的 变量 名 ， 同 时 也 检查 和 符号 表 中 已 有 的 变量 名 的 冲突 。 
处 理 非法 数字 和 冲突 的 键 名 的 方法 将 根据 extract_ type 参数 决定 ， 可 以 是 以 下 值 之 一 。 

EXTR_OVERWRITE: 如 果 有 冲突 ， 覆 盖 已 有 的 变量 。 
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EXTR_SKIP: 如 果 有 冲突 ， 不 覆盖 已 有 的 变量 。 

EXTR_PREFIX_SAME: 如 果 有 冲突 ， 在 变量 名 前 加 上 前 缀 prefix。 

EXTR PREFIX_ALL: 给 所 有 变量 名 加 上 前 级 prefix。 自 PHP 4.0.5 起 这 也 包括 了 对 数字 索引 的 处 理 。 

EXTR_PREFIX_INVALID: 仅 在 非法 数字 的 变量 名 前 加 上 前 缀 prefix。 本 标记 是 PHP 4.0.5 新 加 的 。 

EXTR IF EXISTS: 仅 在 当前 符号 表 中 已 有 同名 变量 时 覆盖 它们 的 值 ， 其 他 的 都 不 处 理 。 可 以 用 在 已 经 定 
义 了 一 组 合法 的 变量 ， 然 后 要 从 一 个 数组 例如 $_REQUEST 中 提取 值 覆盖 这 些 变量 的 场合 。 本 标记 是 PHP 4.2.0 
新 加 的 。 

EXTR_PREFIX IF_EXISTS: 仅 在 当前 符号 表 中 已 有 同名 变量 时 ， 建 立 附 加 了 前 缀 的 变量 名 ， 其 他 的 都 不 
处 理 。 本 标记 是 PHP 4.2.0 新 加 的 。 

EXTR_REFS: 将 变量 作为 引用 提取 。 这 有 力 地 表明 了 导入 的 变量 仍然 引用 了 var_array 参数 的 值 。 可 以 单 
独 使 用 这 个 标志 或 者 在 extract_type 中 用 OR 与 其 他 任何 标志 结合 使 用 。 本 标记 是 PHP 4.3.0 新 加 的 。 

如 果 没 有 指定 extract_type， 则 被 假定 为 EXTR_OVERWRITE。 


上 说 明 : prefix 仅 在 extract type 的 值 是 EXTR PREFIX_ SAME、EXTR _PREFIX_ALL、EXTR PREFIX_ 
INVALID 或 者 EXTR_PREFIX IF_EXISTS 时 需要 ， 如 果 附 加 了 前 组 后 不 是 合法 的 变量 名 ， 将 不 会 
导入 符号 表 中 。 


extract0 函 数 返 回 成 功 导入 到 符号 表 中 的 变量 数目 。 
(3) mb_substr0 函 数 对 字符 串 进行 截取 操作 ， 并 且 支 持 中 文字 符 串 的 截取 ， 其 语法 如 下 : 


string mb_substr ( string str, int start [, int length [, string encoding]] ) 


mb_substr0 函 数 的 参数 说 明 如 表 14.8 所 示 。 


表 14.8 mb_substr() 函 数 的 参数 说 明 
说 明 
必 选 参数 ， 指 定 操作 的 字符 串 
必 选 参数 ， 指 定 截取 的 开始 位 置 。 参 数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 串 中 的 第 一 个 字符 表示 
为 0 
指定 截取 的 字符 串 长 度 
设置 字符 串 的 编码 格式 


图 设计 过 程 

〈1) 创建 system 文件 夹 , 定义 Smarty 文件 夹 , 存储 编译 目录 、 缓 存 目录 ; 创建 类 文件 system.smarty.ine.php， 
定义 数据 库 连 接 、 操 作 、 分 页 和 Smarty 的 配置 类 ， 定 义 类 的 实例 化 文件 system.inc.php， 完 成 各 个 类 的 实例 化 操 
作 并 返回 操作 对 象 。 

(2) 创建 index.php 文件 ， 载 入 类 的 实例 化 文件 ， 编 写 自 定义 函数 unHtml0， 对 论坛 中 的 内 容 进行 截取 操 


作 ; 应 用 register_function0 注 册 模板 函数 ， 分 页 读 取 数 据 库 中 存储 的 论坛 数据 ， 并 且 将 读 取 的 结果 存储 到 模板 
变量 中 ， 最 终 指定 模板 页 ， 其 代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=UTF-8" ): // 设 置 文件 编码 格式 
require_once("system/system.ine.php"): // 调 用 指定 的 文件 
function unHtml($params) { // 创 建 模板 函数 
extract($params): // 读 取 数 据 
if(strlen(Stext)>40){ 

Sstr=mb_substr($text.0.40,"utf-8")."..."; /截取 字符 串 
yelse{ 

$str=$text: 
Teturn $str; // 运 回 截取 结果 
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$smarty->register function("Util" "unHtml"): /注册 模板 函数 
Sarray=$seppage->ShowDate("sclect * from tb_guestbook order by id desc".Sconn.6.$_GET["page"]): /调用 分 页 类 ， 实 现 分 页 
这 !$array){ 
$smarty->assign("iscommo","F"); // 判 断 如 果 执 行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 F 
Yelse{ 
S$smarty->assign("iscommo"."T™"): // 判 断 如 果 执 行 成 功 ， 则 输出 模板 变量 iscommo 的 值 为 
S$smarty->assign("showpage",$seppage->ShowPage(" 帖 子 "" 条 ","","a1")): // 定 义 输出 分 页 数据 的 模板 变量 showpage 


Ssmarty->assign("array".Sarray): 
$smarty->assign('title',register_function(0) 方 法 注册 模板 函数 "); 
$smarty->display('index-html’): 
> 
(3) 创建 index.html 模板 页 获取 模板 变量 传递 的 数据 ， 实 现 数据 的 分 页 输出 ， 并 且 调用 动态 页 中 注册 的 
模板 函数 实现 对 论坛 内 容 的 截取 操作 ， 其 关键 代码 如 下 : 


{section name=id loop=$array} 

<tr> 

<td colspan="4" bgcolor="#FFFFFF">{$arraylid].iid }&nbsp:&nbsp:{Util text=$array[id].title } 积 分 : {$array[id] integralj&nbsp:&nbsp:&nbsp:&nbsp; 
时 间 : {$array[id].createtime}<br>{Util text=$array[id].content}</td> 

<ltr> 

{/section} 


心 法 领悟 578: 字符 串 的 截取 。 
通常 使 用 substr0 函 数 对 字符 串 进行 截取 ， 但 是 该 函数 在 截取 中 文字 符 串 时 ， 很 可 能 导致 截取 的 中 文字 符 串 


不 完整 出 现 乱码 的 情况 。 而 本 实例 中 应 用 的 mb_substr0 函 数 同样 可 以 实现 字符 串 的 截取 功能 ， 并 且 可 以 对 中 文 
字符 串 进行 截取 不 会 出 现 乱 码 的 问题 。 


高 级 | 
实例 579 趣味 指教 : 请 育 育 窜 
实例 说 明 


在 Smarty 中 ， 提 供 了 truncate 方法 对 字符 串 进行 截取 ， 该 方法 可 以 截取 到 一 个 词 的 末尾 。 在 本 实例 中 ， 应 
用 truncate 方法 对 论坛 中 标题 和 内 容 进行 截取 ， 并 且 用 省 略 号 蔡 换 截取 的 内 容 ， 其 运行 结果 如 图 14.31 所 示 。 


为 首页 1 加 入 收获 “1 联系 我 人 
FANXING mn: ern ee /eamn 
324 PHP 可 汉典 。 积分 : 59325 时间: 2010.03.9 名 全 图 片 文件 天 
条 位 专 者: Ny ee 
3 PP 本 得 记 由 亲 此。 和 分: 996 时 间 : 2010.08.19 EE 
各 位 守 首 ; i 硬 各 联系 方式 
3 至 明日 科技 。 积分 时 间 : 32009-1116 区 
对 于 冤 的 报 务 我 非常 铺 害 村 
1 BEP 滴 各 洒 玫 此 。 积分: 的 时 | 硬 鱼 电子 图 区 
各 位 壮 首 ; 水 TU sh 


共和 山子 :条 关 风 显示 6 条 总 1 页 共 1 页 并 页 上 


图 14.31 truncate 方法 截取 字符 串 


图 关键 技术 
truncate 方法 从 字符 串 开 始 处 截取 指定 长 度 的 字符 ， 默 认 是 80 个 字符 。 应 用 示例 如 下 : 
{SarticleTitleltruncate} <!-- 截 取 默认 长 度 的 字符 串 -> 
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{SarticleTitleltruncate:: 30} <!-- 截 取 30 个 字符 --> 


{SarticleTitleltruncate:: <!-- 截 取 30 个 字符 ， 结 尾 处 默认 使 用 省 略 号 进行 添加 --> 
{$articleTitleltruncate: <!-- 截 取 30 个 字符 ， 结 尾 处 以 “---” 进 行 添加 --> 
{SarticleTitleltruncate: <!-- 截 取 30 个 字符 ， 进 行 精确 截取 --> 
{SarticleTitleltruncate:: <!-- 精 确 截取 30 个 字符 ， 以 省 略 号 进行 添加 --> 


其 中 $articleTitle 为 模 极 变量 。 
truncate 方法 的 参数 说 明 如 表 14.9 所 示 。 


表 14.9 truncate 方法 的 参数 说 明 
参 。 数 说 明 
1 | 第 1 个 参数 ， 指 定 截取 字符 的 数量 ， 类 型 为 integer 
2 | 第 2 个 参数 ， 指 定 截取 后 追加 在 截取 词 后 面 的 字符 串 ， 类 型 为 sring 


第 3 个 参数 ， 类 型 为 boolean， 如 果 该 值 为 FALSE， 表 示 截 取 到 词 的 边界 ， 如 果 该 值 为 TRUE， 表 示 截 取 
时 精确 到 指定 字符 


图 设计 过 程 


(1) 创建 system 文件 夹 , 定义 Smarty 文件 夹 , 存储 编译 目录 、 缓存 目录 ; 创建 类 文件 system.smarty.inc.php， 
定义 数据 库 连 接 、 操 作 、 分 页 和 Smarty 的 配置 类 ， 定义 类 的 实例 化 文件 system.inc.php， 完 成 各 个 类 的 实例 化 操 
作 ， 并 返回 操作 对 象 。 

(2) 创建 index.php 文件 ， 载 入 类 的 实例 化 文件 ， 分 页 读 取 数据 库 中 存储 的 论坛 数据 ， 并 且 将 读 取 的 结果 
存储 到 模板 变量 中 ， 最 终 指 定 模板 页 ， 其 代码 如 下 : 


<?php 

require_once("system/system.inc.php"); 1/ 调 用 指定 的 文件 

S$array=$seppage->ShowDate("select * from tb_guestbook order by id desc".Sconn.6.$_GET["page"]): // 调 用 分 页 类 ， 实 现 分 页 
这 !$array){ 

$smarty->assign("iscommo","F"); 1/ 判断 如 果 执行 失败 ， 则 输出 模板 变量 iscommo 的 值 为 F 
jelse{ 

$smarty->assign("iscommo","T"); 1/ 判断 如 果 执行 成 功 ， 则 输出 模板 变量 iscommo 的 值 为 


$smarty->assign("showpage",$seppage->ShowPage(" 帖 子 "" 条 "."","a1")); /定义 输出 分 页 数据 的 模板 变量 showpage 
Ssmarty->assign("array", Sarray); 

} 

$smarty->assign('title','truncate 方法 截取 字符 串 "); // 定 义 标题 

$smarty->display('index.html'); // 指 定 模板 页 

?> 


(3) 创建 index.html 模板 页 ， 获 取 模板 变量 传递 的 数据 实现 数据 的 分 页 输出 ， 并 且 通 过 truncate 方法 对 输 
出 的 标题 和 内 容 进行 截取 操作 : 标题 截取 30 个 字 节 ， 内 容 截 取 60 个 字 节 ， 应 用 省 略 号 补 齐 截取 部 分 ， 其 关键 
代码 如 下 : 


{section name=id loop=$array} 
<tr> 


<td> 

{Sarray[id].id} {Sarray[id].titleltruncate:30:"...":false}: 

积分 : {Sarray[id].integral} 

时 间 : {$array[id].createtimeltruncate:12:""}<br> 
{$arrayfidl.contentltruncate:60:"...":false} 


<ltd> 
<t> 
{/section} 


力 秘笈 心 法 
心 法 领悟 579: 解决 用 truncate 方法 截取 中 文字 符 串 时 出 现 的 乱码 问题 。 
定位 到 Smarty 类 库 的 plugins\modifier.truncate.php 文件 中 , 重新 编辑 smarty_modifier truncate 方法 , 将 其 中 


截取 字符 串 使 用 的 substr0 函 数 全 部 蔡 换 为 mb_substr0 函 数 。 这 样 在 调用 truncate 方法 截取 中 文字 符 串 时 就 不 会 
出 现 乱码 问题 。 
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力 实例 说 明 


缓存 的 合理 应 用 应 该 以 实际 的 开发 需要 为 依据 ， 对 于 那些 需要 经 常 更 新 的 程序 是 否 开启 缓存 ， 如 果 开启 组 
存 ， 周 期 长 短 设置 为 多 少 ， 这 些 都 必须 根据 程序 的 实际 需求 进行 设置 。 在 本 实例 中 ， 开 启 网 站 注册 页 面 的 缓存 ， 
注册 页 面 的 运行 结果 如 图 14.32 所 示 。 


图 14.32 注册 页 面 的 运行 结果 


图 关键 技术 


缓存 的 设置 既 要 考虑 可 以 提高 网 站 的 访问 速度 ， 又 要 考虑 缓存 生命 周期 的 合理 性 。 不 能 偏执 一 方 ， 应 该 采 
取 中 庸 之 道 ， 达 到 最 理想 的 效果 。 

例如 ， 网 站 首页 是 不 需要 经 常 更 新 的 内 容 ， 缓 存 的 生存 周期 就 可 以 设置 长 一 些 ， 而 类 似 于 论坛 中 帖子 的 数 
据 ， 则 可 以 不 开启 缓存 ， 因 为 帖子 的 数据 会 不 断 地 更 新 ， 如 果 使 用 缓存 可 能 会 导致 浏览 不 到 最 新 的 数据 。 

(1) 开启 缓存 。 开 启 缓存 的 方法 非常 简单 ， 只 要 将 Smarty 对 象 中 $config 的 值 设 置 为 TRUE 即 可 ， 同 时 还 


nn 
S$smarty->caching=true: 
S$smarty->cache dir= BASE_ PATH.SMARTY PATH.'cache/': 人 


(2) 设置 缓存 生命 周期 。 缓 存 创建 成 功 后， 必须 为 其 设置 一 个 生命 周期 ， 如 果 它 一 直 不 更 新 ， 那 么 就 没有 
任何 意义 。 设 置 缓存 生命 周期 应 用 的 是 Smarty 对 象 中 的 Scache lifetime 属性 ， 缓 存 时 间 以 秒 为 单位 ， 默 认 值 是 
3600 秒 ， 其 操作 代码 如 下 : 


S$smarty->caching=true; /开启 缓存 
S$smarty->cache_dir =BASE_PATH.SMARTY PATHcache/: // 定 义 缓存 文件 存储 位 置 
S$smarty->cache_lifetime=3600 /设置 缓存 时 间 为 1 小 时 


(3) 判断 模板 文件 是 否 已 经 被 缓存 。 如 果 页 面 已 经 被 缓存 ， 那 么 就 可 以 直接 调用 缓存 文件 ， 而 不 再 执行 动 
态 获取 数据 和 输出 的 操作 。 为 了 避免 在 开启 缓存 后 ， 再 次 执行 动态 获取 数据 和 输出 操作 给 服务 器 带 来 的 压力 ， 
最 佳 的 方法 就 是 应 用 Smarty 对 象 中 的 is_cached0 方 法 ， 判 断 指定 的 模板 是 否 存在 缓存 ， 如 果 存 在 ， 则 直接 执行 


缓存 中 的 文件 ， 否 则 执行 动态 获取 数据 和 输出 的 操作 。 ll 
Ssmarty->caching=true; 


PHP 开发 实例 大 全 (基础 卷 ) 
if(!$smarty->is_cached('index.html){ 
// 执 行动 态 获取 数据 和 输出 的 操作 
TE 
(4) 清除 模板 中 缓存 。 缓 存 的 清除 有 两 种 方法 : 
@ clear all_ cache0) 方 法 清除 所 有 模板 缓存 ， 其 语法 如 下 : 


void clear all cache (int expire time) 
可 选 参数 expire time 可 以 指定 一 个 以 秒 为 单位 的 最 小 时 间 ， 超 过 这 个 时 间 的 缓存 都 将 被 清除 。 
@ clear_cache0 方 法 清除 指定 模板 的 缓存 ， 其 语法 如 下 : 


void clear_cache (string template [, string cache id [ string compile id [, int expire time]]]) 
如 果 这 个 模板 有 多 个 缓存 ， 可 以 用 第 2 个 参数 指定 要 清除 缓存 的 缓存 号 ， 还 可 以 通过 第 3 个 参数 指定 编译 
号 。 可 以 把 模板 分 组 ， 以 便 方便 地 清除 一 组 缓存 。 第 4 个 参数 是 可 选 的 ， 用 来 指定 超过 某 一 时 间 (以 秒 为 单位 ) 


的 缓存 才 会 被 清除 。 
力 设计 过 程 


这 里 在 实例 567 的 基础 上 ， 完 成 用 户 注册 的 功能 ， 并 且 开启 用 户 注册 页 面 的 缓存 。 有 关 缓 存 的 设置 在 


index.php 动态 页 中 完成 ， 其 代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=UTF-8" ); 


// 设 置 文件 编码 格式 
require_once("system/system.inc.php"); /包含 配置 文件 
S$smarty->caching=true; /开启 缓存 
$smarty->cache_lifetime=3600; // 设 置 缓存 过 期 时 间 
//$smarty->clear_all_cache(); /清除 所 有 缓存 
if(!$smarty->is_cached('index.html)){ 

Sres=$conn->execute("select * from tb_bccd "); /| 执行 select 查询 语句 
Sarray=$res->GetArray(): 

Sarray_id=array(); 

Sarray_name=array(): 

for($i=0;$i<$res->RecordCountO:$i++){ 

Sarray_id[]=$array[$i][id]; 

Sarray_name[]=$array[$i][name]; 

} 

S$smarty->assign('cust_id', $array_id); // 设 置 下 拉 列 表 框 的 值 
$smarty->assign('cust_name' $array_name); // 设 置 列表 框 的 显示 数据 
S$array= explode(' ', mt_rand(1000.9999)); /生成 随机 验证 码 
$smarty->assign('title', 开 启 网 站 注册 页 面 的 缓存 '); /将 指定 数据 赋 给 模板 变量 
$smarty->assign('content'.$array); // 将 数组 赋 给 模板 变量 
$smarty->assign('contents', $arrays); // 将 数组 赋 给 模板 变量 
Ssmarty->display('index.html"); /指定 模板 页 

?> 


缓存 文件 存储 在 system\Smarty\cache 目录 下 , 而 存储 路 径 的 设置 是 在 system\system.smarty.inc.php 文件 中 完 
成 的 。 有 关 用 户 注册 的 其 他 功能 ， 请 读者 参考 实例 567， 这 里 不 再 袭 述 。 


国 秘笈 心 法 


心 法 领悟 580: 同一 模板 生成 多 个 缓存 。 


在 实际 的 程序 开发 中 ， 经 常会 遇 到 同一 个 模板 文件 生成 多 个 页 面 的 情况 。 此 时 要 对 这 多 个 页 面 进行 缓存 ， 
就 要 应 用 Smarty 中 的 display() 方 法 ， 通 过 该 方法 的 第 2 个 参数 设置 缓存 号 ， 有 几 个 不 同 的 缓存 号 就 有 几 个 缓存 


页 面 ， 操 作 代 码 如 下 : 
S$smarty->caching=true; /开启 缓存 
S$smarty->cache_dir= BASE PATH.SMARTY PATHcache/: /定义 缓存 文件 存储 位 置 


S$smarty->cache_lifetime=3600; 
Ssmarty->display(index html'$_GET[id]): 
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// 设 置 缓存 时 间 为 1 小 时 
/将 记 作 为 第 2 个 参数 传递 
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实例 581 


力 实例 说 明 


配置 文件 的 应 用 ， 有 利于 设计 者 管理 文件 中 的 模板 全 局 变量 。 例 如 ， 定 义 一 个 模板 色彩 变量 ， 一 般 情况 下 
如 果 想 改变 一 个 程序 的 外 观 色彩 ， 必 须 更 改 每 一 个 文件 的 颜色 变量 。 如 果 有 配置 文件 ， 色 彩 变量 就 可 以 保存 在 
一 个 单独 的 文件 中 , 只 要 改变 配置 文件 就 可 以 实现 色彩 的 更 新 , 这 与 在 Web 页 面 开 发 中 应 用 的 CSS 样式 非常 相 
似 。 在 本 实例 中 ， 将 讲解 如 何 应 用 Smarty 中 的 配置 文件 ， 并 通过 配置 文件 定义 页 面 中 body 标签 的 样式 ， 其 运 
行 结果 如 图 14.33 所 示 。 
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图 14.33 ”通过 配置 文件 定义 页 面 的 样式 


力 关键 技术 


(1) 创建 配置 文件 。 

配置 文件 可 以 任意 命名 ， 其 存储 位 置 由 Smarty 对 象 的 Sconfig_dir 属性 指定 。 如 果 存 在 不 只 在 一 个 区 域内 使 
用 的 变量 值 ， 可 以 使 用 三 引号 〈""") 将 其 完整 地 封装 起 来 。 在 创建 配置 文件 时 ， 建 议 在 程序 运行 前 使 用 “#” 
加 一 些 注释 信息 ， 这 样 有 助 于 程序 的 阅读 、 更 新 。 

在 配置 文件 中 既 可 以 声明 全 局 变量 ， 也 可 以 声明 局 部 变量 。 如 果 声明 局 部 变量 ， 可 以 使 用 中 括号 “[]” 括 起 
来 ， 在 中 括号 之 内 声明 的 变量 属于 局 部 变量 ， 而 中 括号 之 外 声明 的 变量 都 是 全 局 变量 。 中 括号 的 使 用 不 仅 使 配 
置 文件 中 声明 变量 的 模块 变 得 清晰 ， 而 且 可 以 在 模板 中 选择 加 载 中 括号 内 的 变量 。 

(2) 加 载 配置 文件 。 

加 载 配置 文件 应 用 Smarty 的 内 建 函 数 config load， 其 语法 如 下 : 

{config load file="file_name " section="add attribute" scope="" global=""} 

参数 说 明 : 

file: 指定 包含 的 配置 文件 的 名 称 。 

section: 附加 属性 ， 当 配置 文件 中 包含 多 个 部 分 时 应 用 ， 指 定 具体 从 哪 一 部 分 中 取得 变量 。 

scope: 加 载 数据 的 作用 域 , 取 值 必 须 为 local、 parent 或 global。 local 说 明 该 变量 的 作用 域 为 当前 模板 ; parent 
说 明 该 变量 的 作用 域 为 当前 模板 和 当前 模板 的 父 模板 〈 调 用 当前 模板 的 模板 ) ; global 说 明 该 变量 的 作用 域 为 
所 有 模板 。 

global: 说 明 加 载 的 变量 是 否 全 局 可 见 ， 等 同 于 scope=parent。 
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这 提示 : 当 指 定 scope 属性 时 ， 可 以 设置 global 属性 ， 但 模板 忽略 该 属性 值 ， 而 以 scope 属性 为 准 。 


(3) 引用 配置 文件 中 的 变量 。 
配置 文件 加 载 成 功 后 , 就 可 以 在 模板 中 引用 配置 文件 中 声明 的 变量 。 引用 配置 文件 应 用 的 是 “#” 或 者 Smarty 
的 保留 变量 $smarty.config， eid 


{ config load file="file_con.conf’} * 加 载 配置 文件 *} 

{title# 

<td height="228" colspan="2" align="left" valign="top" class=" {$smarty.config.styles}"> 
图 设计 过 程 


(1) 创建 system 文件 夹 ， 定 义 Smarty 文件 夹 ， 存 储 编译 目录 、 缓 存 目 录 和 配置 文件 目录 ; 创建 类 文件 
system.smarty.inc.php， 定 义 Smarty 的 配置 类 ， 在 该 类 中 指定 配置 文件 存储 的 目录 ， 定 义 类 的 实例 化 文件 
system.inc.php， 完 成 Smarty 类 的 实例 化 操作 并 返回 操作 对 象 。 

(2) 创建 index.php 文件 ， 载 入 类 的 实例 化 文件 ， 通 过 文件 系统 函数 fle_get_contents0) 读 取 文本 文件 中 的 
数据 ， 并 且 将 数据 存储 到 模板 变量 中 ， 最 后 指定 模板 页 ， 其 代码 如 下 : 


<?php 

header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文 件 编码 格式 
include("system/systenr ine.php"); // 包 含 配置 文件 

S$str = file_get_contents('files/content.txt); // 读 取 文 本 文件 中 的 数据 
S$smarty->assign('content'iconv("gb2312","utf-8",$str)); // 将 文本 文件 中 的 数据 存储 到 模板 变量 中 
Ssmarty->display(index.html'); // 指 定 模板 页 

> 


(3) 创建 index.html 模板 页 。 首 先 通过 config load0 函 数 加 载 配 置 文 件 ， 然 后 应 用 “#” 和 $smarty.config 
引用 配置 文件 中 的 变量 ， 最 后 通过 模板 变量 输出 文本 文件 中 的 数据 ， 其 关键 代码 如 下 : 


{ config load file="file_con.conf"} {* 加 载 配置 文件 *} 
<title> {#title#} </title> 
<body =" {#leftmargin#}" topmargin=" {#topmargin#}" marginwidth=" {#marginwidth#}" marginheight=" {#marginheight#}"> 
<td height="228" colspan="2" align="left" valign="top" class="{$smarty.config.styles}">{$content}</td> 
图 秘笈 心 法 


心 法 领悟 581: Smarty 模板 的 最 佳 配置 方案 。 
在 本 章 的 实例 中 , 应 用 面向 对 象 技 术 将 配置 方法 封装 到 类 中 , 应 用 Smary 模板 时 调用 类 的 实例 化 文件 即 可 。 
通过 这 种 方法 配置 Smarty 模板 ， 不 必 再 设置 服务 器 的 绝对 路 径 和 Smarty 类 库 的 绝对 路 径 ， 非 常 简单 、 方 便 。 
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15.1 PHP 页 面 编码 


PHP 文件 的 页 面 编码 是 指 文件 以 何 种 形式 保存 ， 其 中 支持 简体 中 文 的 编码 主要 有 GB2312、GBK 和 UTF-8 
等 ， 本 节 将 通过 具体 实例 对 PHP 常用 的 页 面 编码 格式 和 PHP 的 国际 化 进行 讲解 。 


中 级 


| 
人 | 
实例 582 趣味 指数 : 寅 让 全 | 


力 实例 说 明 


本 实例 主要 讲解 如 何 设置 页 面 编码 格式 为 GB2312 编码 ， 运 行 本 实例 ， 如 图 15.1 所 示 ， 在 页 面 中 打印 出 明 
日 企业 网 页 面 编码 的 提示 信息 ， 从 运行 结果 可 以 知道 该 页 面 所 使 用 的 编码 为 GB2312 编码 。 


——— 


Btp1 7 /www mrbeea com 


G 六 局 应 王 丙 


2 鼎 码 格式 的 页 面 


这 是 


15.1 打印 明日 企业 网 的 页 面 编码 


图 关键 技术 


设计 GB2312 编码 格式 的 网 页 需要 进行 两 点 设置 ， 首 先 使 用 编辑 器 设置 页 面 文 件 的 编码 为 GB2312 格式 ， 
然后 通过 HTML 语言 的 meta 标记 或 PHP 的 header0 函 数 设 置 页 面 编 码 为 GB2312。 

设置 页 面 文件 编码 可 以 使 用 UltraEdit、Edit Plus 和 Zend Studio 等 编辑 器 。 下 面 将 以 Zend Studio 为 例 讲解 
如 何 设置 页 面 文件 编码 。 

打开 Zend Studio 后 , 选择 要 设置 编码 的 文件 , 然后 右 击 , 将 弹出 如 图 15.2 所 示 的 快捷 菜单 ， 选 择 Properties 
命令 ， 将 弹出 如 图 15.3 所 示 的 页 面 属性 对 话 框 。 

在 页 面 属性 对 话 框 中 选择 文件 编码 模块 ， 在 该 模块 的 其 他 编码 的 下 拉 列 表 框 中 选择 GBK 编码 ， 然 后 单 击 
编码 的 设置 。 


Lost ediied; 210 年 9 月 17 日 下午 04202 
Besdorly 
cve 


图 15.2 页 面 常规 操作 下 拉 列 表 图 15.3 页 面 属性 对 话 框 
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[ED 说 明 : 在 文件 编码 下 拉 列 表 框 中 并 没有 GB2312 编码 , 而 GBK 编码 包含 简体 中 文 编码 ,所 以 这 里 选择 GBK 
编码 。 


完成 对 页 面 文件 的 编码 设置 后 ， 还 需要 使 用 meta 标记 设置 页 面 编码 ， 其 设置 方法 如 下 : 
<meta http-equiv= "content-type" content="text/html; charset=gb2312" /> 


设计 过 程 
(1) 创建 index.php 页 面 , 并 设置 页 面 文件 的 编码 为 GB2312, 其 具体 设置 方法 已 经 在 关键 技术 中 进行 讲解 ， 
这 里 不 再 资 述 。 
(2) 在 index.php 文件 中 通过 HTML 语言 的 meta 标记 设置 网 页 编码 为 GB2312 格式 ， 具 体 实现 代码 如 下 : 


<!IDOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtmll/DTD/xhtmll -transitional.dtd"> 
<html xmlns="http://Wwww.w3.org/1999/xhtml"> 
<head> 


<title> 设 计 GB2312 编码 格式 的 网 页 </title> 
<meta http-equiv="content-type" content="text/html; charset=gb2312" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 

</head> 

<body> 
<br> 
<div style="width: 487px; text-align:center; height:221px; line-height:221px; font-size:16px; color:blue; background:url(img/bg.jpg)"> 

这 是 一 个 GB2312 编码 格式 的 页 面 

</div> 

</body> 

</html> 


国 秘笈 心 法 

心 法 领悟 582: 在 Dreamweaver 开发 工具 中 设置 文件 的 编码 格式 。 

首先 打开 Dreamweaver 开发 工具 ， 单 击 “ 编 辑 ”按钮 ， 选 择 “ 首 选 参数 ”命令 ， 在 弹出 的 “首选 参数 ”对 
话 框 中 通过 “默认 编码 ”下 拉 列 表 框 设置 创建 文件 的 编码 格式 ， 如 图 15.4 所 示 ， 设 置 完成 后 单 击 “ 确 定 ” 按钮。 


| 
USSD: [Me 
WAZ om) fom resuou 可 


万 党 Control43 外 全 尘 和 显 孙 “新 畦 文档 ”对 活 丁 吧 


Ce] wm | ww | 


图 15.4 在 Dreamweaver 开发 工具 中 设置 文件 的 编码 格式 


趣味 指数 : 食 食 食 


力 实例 说 明 
本 实例 主要 讲解 如 何 设置 网 页 的 页 面 编码 格式 为 GBK。 运 行 本 实例 ,如 图 15.5 所 示 ， 在 页 面 中 打印 出 咖啡 
小 屋 程 序 所 使 用 的 页 面 编 码 。 
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Wal A 


这 是 一 个 CEFE 编 码 格 式 的 页 面 


图 15.5 打印 咖啡 小 屋 的 页 面 编码 


图 关键 技术 


本 实例 的 关键 技术 是 设置 网 页 的 页 面 编码 格式 为 GBK， 同 样 其 设置 方法 也 包括 两 个 部 分 。 首 先 设置 网 页 文 
件 的 编码 为 GBK 格式 ， 其 设置 方法 与 实例 582 相同 ， 这 里 不 再 著述 。 然 后 使 用 HIML 语言 的 meta 标记 设置 网 
页 的 编码 为 GBK， 其 设 定 代码 如 下 : 

<meta http-equiv="content-type" content="text/html; charset=gbk" /> 
力 设计 过 程 

(1) 创建 index.php 文件 ， 并 使 用 Zend Studio 编辑 器 设置 页 面 文件 编码 格式 为 GBK。 
(2) 在 index.php 文件 中 使 用 meta 标记 设置 网 页 编码 格式 为 GBK， 并 在 页 面 中 打印 当前 页 面 所 使 用 的 编 
码 ， 其 具体 代码 如 下 : 


<!IDOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtmll/DTD/xhtmll -transitional.dtd"> 
<html xmlns="http://Wwww.w3.org/1999/xhtml"> 
<head> 


<title> 设 计 GBK 编码 格式 的 网 页 </tide> 

<meta http-equiv="content-type" content="text/html; charset=gbk" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 

</head> 
<br> 
<div style="width: 498px; text-align:center; height:332px; line-height:221px; font-size:16px; color:#FF3300; background:url(img/bg.jpg)"> 

这 是 一 个 GBK 编码 格式 的 页 面 

</div> 

</body> 

</html> 


图 秘笈 心 法 
心 法 领悟 583: GB2312 和 GBK。 
GB2312 和 GBK 是 中 国政 府 颁布 的 标准 汉字 编码 。GB2312 编码 中 放置 了 6763 个 常用 汉字 ， 并 且 首 次 在 中 


文 操作 系统 CCDOS 中 使 用 ，GBK 编码 在 GB2312 编码 的 基础 上 ， 增 加 了 我 国 台湾 BIG5 编码 中 的 15000 多 个 
汉字 的 字符 。 


中 级 
趣味 指数 : 食 食 食 


实例 584 


力 实例 说 明 
本 实例 主要 讲解 如 何 设置 网 页 页 面 编码 格式 为 UTF-8。 运 行 本 实例 ， 如 图 15.6 所 示 ， 将 在 页 面 中 打印 出 企 
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业 邮 局 收发 系统 所 使 用 的 页 面 编码 。 


(OVE MB 


当前 位 置 > 电 子 莉 件 发 关 >> 状 伞 箱 


= 
和 
这 是 一 个 UTF-8 编 码 格式 的 页 面 
好友 录 


语录 


人 
15.6 ”打印 企业 邮局 收发 系统 页 面 编码 


图 关键 技术 


UTF 是 国际 字符 集 转换 格式 (Unicode/UCS Transformation Format) 的 缩写 ,是 FCS 的 实际 表达 式 ， 按 其 基 
本 长 度 所 用 位 数 分 为 UTF-8/16/32 这 3 种 形式 ， 其 中 UTF-8 保持 字符 数字 一 个 字 节 ， 其 他 的 用 不 定 长 编码 到 最 
多 6 个 字 节 ， 支 持 到 31 位 编码 。UTF 中 最 常用 的 就 是 UTF-8 编码 格式 ，UTF-8 使 用 8 位 字 节 编码 ， 通 常 使 用 
1~3 位 字 节 来 表示 一 个 字符 ， 字 符 的 编码 长 度 为 变 长 。 

UTF-8 字符 集 不 仅 包 括 欧美 字符 ， 也 包括 中 国 、 日 本 和 韩国 的 全 角 字 符 。 因 此 ， 在 网 页 中 使 用 UTF-8 字符 
集 可 以 使 用 户 在 不 安装 中 文 编码 的 情况 下 浏览 到 大 部 分 中 文字 符 。 


本 实例 设置 页 面 为 UTF-8 编码 ， 首 先 需 要 使 用 编辑 工具 设置 页 面 文件 编码 格式 为 UTF-8， 然 后 使 用 HTML 
的 meta 标记 设置 网 页 编码 格式 为 UTF-8， 其 设置 方法 如 下 : 


<meta http-equiv="content-type" content="text/html; charset=utf-8" /> 
图 设计 过 程 


(1) 新 建 ndex.php 文件 ， 并 使 用 Zend Studio 编辑 器 设置 页 面 文件 编码 格式 为 UTF-8。 
(2) 在 HIML 语言 的 meta 标记 中 设 定 当 前 页 面 所 使 用 的 编码 格式 为 UTF-8， 其 具体 代码 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtmll/DTD/xhtmll -transitional.dtd"> 
<html xmlns="http://Wwww.w3.org/1999/xhtml"> 
<head> 
<title> 设 计 UTF-8 编码 格式 的 网 页 </title> 
<meta http-equiv="content-type" content="text/html: charset=utf-8" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<br> 
<div style="width: 978px: text-align:center: height:591px: line-height:591px: font-size:16px: color:#09600C: background:urllimg/bgjpg)"> 
这 是 一 个 UTF-8 编码 格式 的 页 面 
</div> 
</body> 
</html> 


力 秘笈 心 法 


心 法 领悟 584: Web 程序 开发 中 页 面 编码 格式 的 选择 。 


为 了 便于 程序 的 国际 化 及 使 程序 支持 更 多 语言 版 本 的 操作 系统 ， 在 项 目 开 发 中 建议 将 页 面 设置 为 UTF-8 编 
码 格式 。 
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实例 585 


力 实例 说 明 


信息 全 球 化 的 高 速 发 展 ， 使 企业 的 市 场 也 在 逐步 扩大 ， 并 逐渐 走向 世界 。 企 业 向 世界 展示 自己 ， 必 不 可 少 
地 要 应 用 到 互联 网 ， 在 应 用 互联 网 的 过 程 中 必须 要 提供 多 国语 言 的 支持 。 只 有 这 样 才 能 让 更 多 的 人 了 解 企业 。 
所 以 在 开发 程序 的 过 程 中 ， 必 须要 提供 对 多 国语 言 的 支持 。 本 实例 以 一 个 简单 的 企业 内 部 管理 系统 为 例 ， 介 绍 
如 何 通过 PHP 语言 开发 提供 多 国语 言 支持 的 程序 。 在 实例 中 ， 实 现 文章 的 添加 和 浏览 功能 ， 并 且 提供 对 中 文 和 
英文 两 种 语言 的 支持 。 中 文 文章 添加 页 面 如 图 15.7 所 示 ， 英 文 文章 添加 页 面 如 图 15.8 所 示 。 


EW | Woo | EW | ete 
图 15.7 中文 文章 添加 页 面 图 15.8 英文 文章 添加 页 面 
图 关键 技术 
本 实例 中 应 用 到 的 关键 技术 如 下 : 


(1) 网 页 编码 的 设置 。 在 网 页 中 , 字符 编码 通过 <head> 标 签 中 <meta> 标 签 的 charset 属性 来 设置 ,代码 如 下 : 


<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 


<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 设 置 网 页 编码 格式 </title> 

</head> 

<body> 通 过 meta 标签 的 charset 属性 设置 字符 编码 格式 </body> 
</html 


(2) 获取 客户 端 语言 选项 ， 根 据 语言 选项 的 值 调 用 不 同 的 语言 配置 文件 ， 代 码 如 下 : 


session start(): 
Slang=$_SERVER['HTTP_ACCEPT LANGUAGE": /获取 语言 选项 
Slang=explode(';', Slang); te i 
Slang=$lang[0]; // 为 数组 虐 
Slang=explode(',, Slang); 1 对 字符 进行 分 了 
Slang=$lang[0]: // 为 数组 赋值 
switch($lang){ /根据 获取 到 的 语言 选项 的 值 为 变量 赋值 
Case "en-us": 

Slang="en' 

break; 
case "zh-cn": 

Slang="ch 
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Slang="en"; 
break; 
} 
这 isset($_SESSION[lang])){ 
Slang=$_SESSION[lang']: // 为 SESSION 变量 赋值 
} 
include "lang/lang_ $lang php"; // 调 用 不 同 的 语言 配置 文件 


> 


其 中 ，$_SERVER['HTTP_ACCEPT LANGUAGE'] 为 服务 器 变量 ， 用 于 获取 客户 端 浏览 器 的 语言 设置 
图 设计 过 程 


(1) 创建 conn 文件 夹 ， 编 写 conn.php 文件 ， 完 成 与 数据 库 的 连接 ， 其 代码 如 下 : 
<?php 
$conn=mysql_connect("localhost","root","111") or die(' 连 接 失败 . mysql_error0);: 
mysql_select_db("db_database15",Sconn) or die (数据 库 选择 失败 . mysql_error0): 
mysql_query("set names gb2312"); 
?> 


(2) 创建 lang 文件 夹 , 编写 lang_ch.php 和 1lang_en.php 文件 , 分 别 定义 中 文 语 言 配置 和 英文 语言 配置 文件 ， 
代码 请 参考 附送 光盘 中 的 内 容 。 

(3) 创建 config.php 文件 ， 获 取 浏览 器 中 语言 选项 的 值 ， 根 据 语言 选项 的 值 调用 不 同 的 语言 配置 文件 。 其 
完整 代码 可 以 参考 关键 技术 中 的 内 容 。 

(4) 创建 setlang.php 文件 ， 根 据 超 链接 中 传递 的 参数 为 SESSION 变量 赋值 ， 并 且 调 用 不 同 的 操作 页 面 ， 


其 代码 如 下 : 
<?php 
session start(); 
switch($_GET['lang]){ // 获 取 超 链接 传递 的 语言 选项 的 值 
让 “$_SESSION[lang]="en"; // 根 据 超 链 接 的 值 为 SESSION 变量 赋值 
break; 
ease "ch": 


$_SESSION['lang']="ch": 
break: 


default : 
$_SESSION[ lang']="en"; 
break; 


} 

if($_GET[link]—"addnew"){ // 根 据 超 链接 的 值 跳 转 到 不 同 操作 页 面 
header("Location:addnew.php"); 

Yelseif ($ GETTTink1 一 "show"f 
header("Location:show.php"): 

Jelse{ 


header("Location:index.php"): 

} 

?> 

(5) 创建 index.php 文件 ， 根 据 选择 的 语言 不 同 输出 不 同 的 页 面 和 内 容 。 首 先 通 过 require_once 语句 调用 
不 同 的 包含 文件 ， 完 成 数据 库 连接 和 语言 配置 。 然 后 执行 查询 操作 ， 从 数据 表 中 读 取 指 定 的 数据 信息 。 最 后 在 
页 面 中 输出 数据 ， 其 关键 代码 如 下 : 


<?php 

require_once('conn/conn .php)): // 连 接 数据 库 
require_once('config.php"); // 调 用 语言 配置 文件 
$query_rs="select * from tb_articles where langver=$rs_filter order by id desc": /定义 查询 语句 
S$rs=mysql_query($query_rs.$conn) or die(mysql_errorO): // 执 行 查询 操作 
Srow_rs=mysql_fetch_assoc($rs); // 获 取 查 询 结 果 的 记录 数 


(6) 创建 add_dataphp 文件 ， 添 加 form 表单 用 于 提交 数据 并 完成 对 表单 中 数据 处 理 的 操作 。 首 先 通过 
require_once 语句 调用 不 同 的 包含 文件 ,完成 数据 库 连 接 和 语言 配置 。 然 后 定义 方法 GetSQLValueString0 完 成 对 数 
据 格 式 的 转换 。 接 着 获取 表单 中 提交 的 数据 ， 并 应 用 sprintf0 函 数 和 GetSQLValueString0 方 法 完成 对 数据 格式 的 转 
换 将 数据 添加 到 数据 表 中 。 最 后 设计 文章 添加 页 面 ， 创 建 form 表单 ， 完 成 数据 的 提交 操作 ， 其 关键 代码 如 下 : 
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<php 

require_once(' conn /conn.php'): /连接 数据 库 
require_once('config.php'); /配置 语言 
/定义 格式 转换 的 方法 


fanetion GetSQLValueString($theValue. StheType. StheDefinedValue="",$theNotDefinedValue="){ 
StheValue=(!get_magic_quotes_gpe0) ? addslashes($theValue):$theValue; 
switch(StheTypej{ 


mext": 
StheValue=($theValue !="")? "". $theValue. ™™" : "NULL"; 
break; 


retum $theValue; 


if($_POST["Submit"]—TRUE){ 
1/ 获取 表单 中 提交 的 数据 ， 并 完成 对 数据 格式 的 转换 
SinsertSQL=sprintf("insert into tb_articles(topic,author,comefrom.,content,langver) values(%s,%s,%s,%s,%s)", 
GetSQLValueString($_POST['topic'], "text"), 
GetSQLValueString($_POST['author],"text"), 
GetSQLValueString($_POST[ comefrom'], "text"), 
GetSQLValueString($_POST['content],"text"), 
GetSQLValueString($ POST[ langver],"text") 
); 
/执行 添加 语句 ， 将 数据 添加 到 数据 表 中 
SResultl=mysql query($insertSQL.Sconn) or die(mysql error()); 
echo "<script>alert($add_data_Suc): window.location href=‘add_data.php':</script>"; 
上 
(7) 创建 look_over.php 文件 ， 根 据 超 链接 传递 的 ID 值 执行 查询 操作 ， 输 出 指定 文章 的 详细 信息 ， 代 码 请 
参考 光盘 中 内 容 。 


图 秘笈 心 ; 

心 法 领悟 585: 设置 数据 库 中 数据 输出 的 编码 格式 。 

设置 数据 库 中 数据 输出 的 编码 格式 在 conn.php 文件 中 进行 ， 通 过 mysql_query0 函 数 完成 ， 本 实例 中 设置 的 
是 GB2312 编码 格式 。 切 记 ， 这 里 设置 的 编码 格式 必须 与 数据 库 中 字段 的 编码 格式 相同 ， 否 则 在 输出 数据 库 中 
的 数据 时 将 出 现 乱码 。 


如 果 没 有 在 conn.php 文件 中 进行 数据 库 编码 格式 的 设置 ， 在 输出 数据 库 中 的 数据 时 ， 如 果 页 面 编码 格式 与 
数据 库 中 字段 设置 的 编码 格式 不 同 ， 那 么 输出 中 文字 符 串 时 有 可 能 出 现 乱码 。 


15.2 ”网 站 公共 文件 设计 


在 进行 项 目 开 发 时 ， 为 提高 代码 的 重用 率 及 方便 系统 维护 ， 经 常 需要 将 Web 程序 中 的 共性 功能 进行 封装 ， 
本 节 将 通过 具体 实例 讲解 网 站 公共 文件 的 设计 方法 和 具体 应 用 。 


力 实例 说 明 


明日 科技 书店 网 站 的 数据 库 管理 采用 ADODB 数据 库 抽象 层 技术 ， 使 用 ADODB 技术 连接 数据 库 ， 可 以 实 
现 与 多 种 数据 库 进 行 连接 。 本 实例 所 建立 的 数据 库 连 接 类 可 以 实现 与 MySQL、SQL Server 和 Access 的 连接 ， 
是 一 个 扩展 能 力 较 强 的 数据 库 连 接 类 。 明 日 科技 书店 首页 的 运行 效果 如 图 15.9 所 示 。 
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图 15.9 明日 科技 书店 成 功 连接 MySQL 数据 库 的 首页 运行 效果 


图 关键 技术 


本 实例 的 关键 是 设计 一 个 可 以 对 多 种 数据 库 进行 连接 的 数据 库 连 接 类 。 下 面 对 数据 库 连接 类 的 制作 方法 进 


行 详细 讲解 : 
(1) 首先 定义 数据 库 连 接 类 的 属性 ， 关 键 代码 如 下 : 

var $dbType; /| 数据库 类 型 标识 
var $host; /数据库 服务 器 地 址 
Var $userName; /| 数据 库 服务 器 用 户 名 
var $password: /数据 库 用 户 密码 
var $dbName; // 要 连接 的 数据 库 名 
var $isDebug; /是 否 显示 调试 信息 
var $connID 


上 加 说 明 : 这 里 为 了 兼容 PHP 5.0 以 下 的 版 本 ， 所 有 属性 都 定义 成 var 类型。 
(2) 定义 数据 库 连 接 类 的 构造 方法 ， 实 现 对 类 内 属性 的 初始 化 ， 其 关键 代码 如 下 : 


function ConnDB ($dbType = 'mysql', $host, $userName, $password, $dbName, SisDebug = false){ 
Sthis->dbType = $dbType: // 为 数据 库 类 型 赋 初 值 


S$this->host = $host; // 为 服务 器 地 址 赋 初 值 
S$this->userName = $userName; // 为 用 户 名 赋 初 值 
S$this->password = $password; // 为 密码 赋 初 值 
Sthis->dbName = $dbName; // 为 数据 库 名 赋 初 值 
S$this->isDebug = $isDebug; // 为 调试 信息 赋 初 值 


} 


[上 说 明 : 上 述 代码 中 的 “->” 是 PHP 面向 对 象 编程 方式 中 ， 实 例 化 的 对 象 引用 类 中 方法 或 属性 的 标识 符 。 


(3) 通过 ConnDBO 构 造 方法 对 类 中 属性 初始 化 后 ， 就 可 以 实现 与 数据 库 的 连接 。 具 体 连 接 过 程 通过 方法 
getConnIDO 实 现 ， 在 该 方法 中 根据 属性 SdbType 的 值 来 判断 要 连接 数据 库 的 类 型 ， 并 根据 不 同 的 数据 库 类 型 选 
择 相应 的 数据 库 连接 驱动 最 终 返回 连接 对 象 ， 其 关键 代码 如 下 : 


function getConnID O{ 
require_once Hibraryladodbladodb inc php': 


Sthis->connID = NewADOConnection($this->dbType): 
if($this->dbType 一 mysql || $this->dbType 一 mssql) { 


// 导 入 ADODB 类 库 
// 生 成 数据 库 连接 对 象 
// 如 果 为 MySQL 数据 库 或 者 SQL Server 数据 库 


S$this->connID->Connect($this->host. $this->userName. $this->password, $this->dbName): // 通 过 Connect0 方 法 建立 与 数据 库 的 连接 


if (Sthis->dbType — ‘mysql) { 


Sthis->connID->Execute('set names gb2312"): 


} 
} elseif (Sthis->dbType 一 access) { 


// 设 置 数据 库 编码 
// 如 果 为 Access 数据 库 
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Sthis->connID->Connect(Driver = {Microsoft Access Driver (* mdb)}j: Dbq = .realpath(Sthis->dbName) . “Uid =". $this->userName . ‘Pwd 
=". Sthis->password . ;); 
}else{ 


retum false; 
S$this->connID->debug = $this->isDebug: /| 是否 调 试 
retum $this->connID; // 返 回 数据 库 连接 对 象 


上 述 代 码 首 先 使 用 require_once0 函 数 包含 ADODB 中 的 adodb.inc.php 文件 , 这 样 就 实现 了 将 ADODB 类 库 
包含 到 工程 中 ， 然 后 根据 属性 $dbType 的 值 判 断 要 连接 数据 库 的 类 型 ， 根 据 不 同 的 数据 库 类 型 选择 不 同 的 连接 
方式 ， 最 后 通过 return 语句 返回 数据 库 连 接 对 象 。 在 进一步 开发 中 ， 只 需 通过 该 方法 返回 的 数据 库 连 接 对 象 来 
调用 相应 的 方法 (如 Execute() 方 法 ) 即 可 实现 对 数据 库 的 查询 。 

(4) 完成 对 数据 库 的 操作 后 ， 还 需要 关闭 对 数据 库 的 连接 ， 这 里 通过 closeConnID0 方 法 实现 ， 其 代码 如 下 : 


function closeConnID O{ 
@$this->connID->Disconnect(); /| 关闭 与 数据 库 的 连接 


} 
以 上 为 数据 库 连接 类 ConnDB 的 全 部 核心 内 容 ， 主 要 实现 对 不 同类 型 数据 库 的 连接 及 在 操作 完 数据 库 后 释 
放 资 源 等 操作 。 


力 设计 过 程 
(1) 建立 数据 库 连接 类 ConnDB， 其 具体 实现 代码 已 经 在 关键 技术 中 进行 了 讲解 ， 这 里 不 再 效 述 。 
(2) 在 lzhConfig.ini 文件 中 配置 各 项 数据 库 连接 参数 的 值 ， 具 体 配 置 代码 如 下 : 


[database-config] 
dbType = mysql 

host= 127.0.0.1 
userName = root 
password = 111 

dbName = db_database15 
isDebug = false 


(3) 对 ConnDB 类 进行 实例 化 ， 并 使 用 实例 化 后 的 对 象 调 用 类 中 的 getConnID0 方 法 返回 数据 库 连 接 标识 ， 


从 而 实现 与 数据 库 的 连接 ， 代 码 如 下 : 


SconnDB = new ConnDB($arrayInil'dbType'] ,SarrayIni[ host] ,SarrayIni['userName'] ,SarrayIni['password'] ,SarrayIni[ dbName'] ,SarrayInil'isDebug']); 
SconnID = $connDB->getConnID(): 


国 秘笈 心 法 


心 法 领悟 586: 屏蔽 程序 中 的 运行 错误 。 
在 开发 PHP 项 目 时 ， 可 以 通过 在 语句 前 加 “@” 符 号 来 屏蔽 运行 时 的 错误 。 


实例 587 


力 实例 说 明 


为 了 对 项 目 中 的 SQL 语句 进行 统一 管理 ， 提 高 代码 重用 率 和 项 目的 可 维护 性 ， 本 实例 将 数据 库 的 增 、 删 、 
改 、 查 操作 通过 专门 的 数据 库 管理 类 实现 ， 在 明日 科技 书店 网 站 获取 图 书 内 容 简介 就 是 使 用 该 类 实现 的 ， 其 运 
行 效果 如 图 15.10 所 示 。 
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书 名 《Visual C8 硕 目 开 友 实 二 自学 插 基 (1CD)3 


图 15.10 图书 信息 简介 


图 关键 技术 


在 数据 库 管理 类 AdminDB 中 ， 只 有 一 个 名 为 executeSQL( 的 方法 , 通过 该 方法 可 以 实现 对 数据 库 的 所 有 查 
询 和 维护 操作 ， 其 关键 代码 如 下 : 


class AdminDB{ 
function executeSQL ($sql, $connID){ 


$sqlType = strtolower(substr(trim($sql), 0, 6)); /| 提取 SQL 语句 的 类 型 
Srs = $connID->Execute($sql); /| 执行 SQL 语句 
ff($sqlType = 'select) { // 如 果 是 select 查询 
SarrayData = $rs->GetRows(); // 返 回 查询 记录 集 
if(count($arrayData) 一 0 || $rs — false) { // 如 果 没 查询 到 或 发 生 错误 
return false; // 返 回 FALSE 
}else{ /否则 
return $arrayData; // 返 回 记 录 集 


} 
} elseif ($sqlType 一 insert || $sqlType — ‘update’ || $sqlType — ‘delete’) { 

// 如 果 执行 插入 、 更 新 或 删除 语句 

retum $rs; // 返 回 语句 执行 状态 ， 即 成 功 返 回 TRUE， 失 败 返 回 FALSE 
}else{ 

returm false; // 如 果 不 是 上 述 查 询 ， 则 返回 FALSE 
} 


} 
上 述 数 据 库 管理 类 中 的 executeSQL0 方 法 包含 $sql 和 $connID 两 个 参数 ， 分 别 为 要 执行 的 SQL 语句 和 数据 
库 连接 对 象 。 在 函数 体内 ， 首 先 将 传 入 的 SQL 语句 转换 成 小 写 ， 然 后 提取 SQL 语句 的 前 6 个 字符 ， 同 时 通过 
数据 库 连 接 对 象 的 Execute0 方 法 执行 SQL 语句 ， 并 根据 提取 的 SQL 语句 的 前 6 个 字符 判断 SQL 语句 的 类 型 ， 
从 而 返回 查询 结果 。 
看 设计 过 程 
(1) 建立 数据 库 管 理 类 AdminDB， 该 类 的 创建 过 程 已 经 在 本 实例 的 关键 技术 中 进行 了 详细 介绍 ， 这 里 不 
再 袭 述 ， 然 后 使 用 new 关键 字 对 该 类 进行 实例 化 ， 实 现代 码 如 下 : 
SadminDB = new AdminDBO: 
(2) 使 用 AdminDB 类 实例 的 对 象 调 用 该 类 中 的 executeSQL0 方 法 执行 查询 ， 并 将 查询 结果 赋 给 视图 变量 ， 
实现 该 过 程 的 关键 代码 如 下 : 


S$bookinfo = $adminDB->executeSQL("select tb_bookinfo.id as bid. bookname, bookids, page, isbn. zs. bookce, be about, directory. writer, pubname, 
Pubtime, bookimg, typename, oldprice, newprice from tb_boakinfo tb_pub, tb_smalltype where tb_bookinfo pubid =tb_pub.id and 
tb_bookinfo.smalltypeid = tb_smalltype.id and tb_bookinfo.id="™ . $bid . "", $connID): // 查 询 图 书信 息 
S$smarty->assign('bookinfo', $bookinfo); // 将 图 书信 息 赋 给 视图 变量 

(3) 在 bookinfo.phtml 视图 文件 中 ， 根 据 传递 的 视图 变量 的 值 打印 图 书 的 各 项 信息 ， 其 具体 实现 代码 请 详 


见 本 书 附带 光盘 。 
图 秘笈 心 ; 
心 法 领悟 587: 根据 select、update 和 delete 关键 字 的 字符 串 长 度 完成 SQL 语句 类 型 的 判断 。 
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之 所 以 要 在 数据 库 管 理 类 中 提取 SQL 语句 的 前 6 个 字符 ， 是 利用 select、update 和 delete 关键 字 的 字符 长 
度 都 是 6 个 字 节 的 特点 ， 通 过 截取 的 6 个 字 节 可 以 判断 出 SQL 语句 的 类 型 。 


中 级 
趣味 指数 催 机 人 


实例 588 


力 实例 说 明 


为 了 有 效 地 利用 页 面 资 源 ， 设 计 出 合理 的 页 面 布局 ， 在 制作 明日 科技 书店 的 图 书信 息 展示 模块 时 采用 分 页 
的 方式 ， 明 日 科技 书店 的 新 书 分 页 展示 模块 如 图 15.11 所 示 。 
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力 关键 技术 


如 果 每 个 图 书信 息 展示 模块 都 编写 类 似 的 代码 实现 分 页 ， 不 仅 会 降低 开发 效率 ， 还 为 生产 环境 下 的 维护 带 
来 很 大 负担 。 为 解决 上 述 问题 ， 将 图 书 的 分 页 功能 封装 成 分 页 类 ， 只 需 在 需要 使 用 分 页 展示 图 书信 息 的 页 面 调 
用 该 类 的 相应 方法 即 可 。 下 面 介绍 分 页 类 的 实现 方法 ， 其 代码 如 下 : 


class PageDB{ 
function pageData ($sql, $connID, $pageSize, Spage){ 
SarrayPageInfo = array(): /用 于 保存 分 页 信息 的 数组 
SnowPage = $page: // 当 前 页 码 
Srs = $connID->PageExecute($sql, SpageSize, S$nowPage); // 通 过 ADODB 的 PageExecute0 方 法 获得 指定 页 码 的 记录 集 

S$arrayData = $rs->GetRows():; // 将 结果 保存 到 数组 中 

aime li$rs — false) { // 如 果 没 有 查询 到 内 容 ， 则 返回 FALSE 
return false: 

}else{ 
SarrayPageInfo['data'] = SarrayData: // 每 页 的 数据 

=$connID->Execute($sq)); 


‘$sql); 
$countRs = count(SrsAIL>GetRowsO): 
$countPage = ceil($countRs / $pageSize): 


SarrayPageInfo['pageSize'] = $pageSize; /每 页 显示 记录 的 条 数 
SarrayPageInfo['countRs'] = $countRs; /总 记录 数 
$arrayPageInfo[page] = SnowPage: /当前 页 
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SarrayPageInfo['countPage'] = $countPage: /总 页 数 
$arrayPageInfo['first]= 1: /第 一 页 的 页 码 
if(Spage> 1) { 
SarrayPageInfo['previous'] = $rs->AbsolutePage() - 1: 1/ 前 一 页 的 页 码 
Yelse{ 
SarrayPageInfo[ previous] = 1; 
} 
es < $countPage) { 
arrayPageInfo['next] = $rs->AbsolutePage() + 1; // 后 一 页 的 页 码 
} 
SarrayPageInfo['next] = $countPage; 
} 
SarrayPageInfo['last] = $countPage; // 最 后 一 页 的 页 码 
} 
return $arrayPageInfo; 


} 

上 述 分 页 类 实现 的 原理 是 : 设法 使 用 ADODB 数据 抽象 层 获取 指定 页 码 中 所 显示 的 数据 ， 同 时 将 首页 、 上 
一 页 、 下 一 页 、 尾 页 、 总 页 码 和 总 记录 数 都 作为 数组 元 素 ， 然 后 将 该 数组 作为 分 页 类 中 实现 分 页 方法 的 返回 值 
返回 ， 在 需要 分 页 的 模块 ， 只 需要 通过 分 页 类 获取 该 返回 数组 就 可 以 获得 所 有 分 页 所 需 信息 。 

在 实现 上 述 PageDB 分 页 类 时 ， 在 类 体内 只 定义 一 个 pageData0 分 页 方法 ,在 该 方法 内 部 , 通过 ADODB 数 
据 抽象 层 根据 分 页 方法 的 SpageSize 和 $page 参数 获取 页 面 显示 的 数据 和 分 页 导航 参数 ， 并 保存 到 $arrayPageInfo 
数组 中 返回 。 


图 设计 过 程 

(1) 建立 数据 库 分 页 类 PageDB， 并 在 该 类 中 建立 pageData() 方 法 ， 该 类 的 创建 过 程 已 经 在 关键 技术 中 给 
出 ， 这 里 不 再 效 述 。 

(2) 在 listsepbook.php 文件 中 ， 包 含 网 站 头 文件 ， 根 据 超 链接 传递 的 参数 值 为 变量 赋值 ， 调 用 数据 库 管 理 
类 中 的 方法 执行 查询 语句 ， 并 且 将 返回 的 查询 结果 赋 给 模板 变量 。 定 义 分 页 变量 ， 调 用 分 页 类 中 的 方法 完成 数 
据 的 分 页 输出 ， 同 时 将 分 页 方法 返回 的 数据 赋 给 模板 变量 ， 最 后 指定 模板 页 ， 其 关键 代码 如 下 : 


require_once header.php'; // 包 含 header.php 文件 
if($_GET[t] = new') { // 展 示 新 书 
Snowtype = 新 书 推荐 ; 
Sandwhere = "isnew = 1"; 
} elseif ($_GET[+] — ee) { // 展 示 特价 图 书 
Snowtype = 特价 


Sandwhere = ee 1"; 
} elseif ($_GET[Y] 一 ‘hotsell) { 
Snowtype= ' 热 卖 图 书 ; /展示 热卖 图 书 
Sandwhere = "ishotsell = 1"; 
} elseif ($ eles ‘term) { 
书 '; 


} elseif ($_GETI+]— Sbook { /展示 明日 图 书 
Snowtype =' 明 日 图 书 推荐 '; 
Sandwhere = "ismrbooktj = 1": 
} 
S$smarty->assign('gt, $_GET[t]): // 为 模板 变量 赋值 
S$smarty->assign('nowtype', $nowtype): 
S$system = $adminDB->executeSQL("select bookimgurl, readurl from tb_system where mark = 1", $connID); /执行 查询 语句 


Ssmarty->assign('system', $system); // 将 查询 结果 赋 给 模板 变量 
if(! isset($_GET['page')) || $_GET['page] —") { 1/ 判断 分 页 变量 的 值 
ee // 设 置 分 页 变量 的 值 


}else{ 
, Spage =$_GET['page']: 

$sql = "select tb_bookinfo.id, tb_bookinfo.bookimg, tb_bookinfo_about tb_bookinfo.browsertime. tb_bookinfo.oldprice, tb_bookinfo.newprice, 
tb_bookinfo.bookname, tb_bookinfo.writer, tb_bookinfo.pubtime. tb_bookinfo.addtime, tb_bookinfo ishave. tb_pub.pubname from tb_bookinfo. tb_pub 
‘where tb_bookinfo.pubid = tb_pub.id and " . $andwhere . " order by tb_bookinfo.addtime desc": // 定 义 查询 语句 

Sbookinfos = SpageDB->pageData($sql. $connID. 10. Spage): // 调 用 分 页 类 中 的 方法 ， 执 行 查询 操作 
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Ssmarty->assign(bookinfos' $bookinfos); // 将 分 页 方法 返回 的 数组 赋 给 模板 变量 
S$smarty->display('listsepbook.phtml); // 指 定 模板 页 
Tequire_once ‘footer.php'; // 包 含 页 面 的 尾 文件 


(3) 在 views\listsepbook.phtml 模板 页 中 完成 数据 的 分 页 输出 ， 其 代码 请 参考 光盘 中 的 内 容 。 


心 法 领悟 588: 分 页 方法 的 完善 。 
在 本 实例 中 ， 采 用 的 是 首页 、 上 一 页 、 下 一 页 和 尾 页 的 分 页 模式 ， 如 果 读 者 感 兴趣 也 可 以 对 这 种 分 页 模式 
进行 更 新 使 其 更 加 个 性 化 ， 分 页 类 存储 于 library\PageDB.php 文件 中 。 


置 类 中 级 | 
sp /5| i 
一 | = ee 
轿 实例 说 明 
Smarty 是 PHP 的 模板 引擎 ， 通 过 Smarty 可 以 将 开发 人 员 和 美工 人 员 相 互 独立 开 来 ， 在 项 目 开 发 中 ， 后 台 
编码 和 前 台 设计 可 以 同步 进行 。 在 对 项 目 进行 维护 的 过 程 中 , 页 面 更 改 不 会 影响 业务 逻辑 的 实现 。 同时 ，Smarty 
模板 增加 了 视图 缓存 和 静态 页 面 生 成 机 制 ， 从 而 可 以 有 效 提高 项 目的 执行 效率 。 
明日 科技 图 书 网 站 就 是 应 用 Smarty 模板 完成 网 站 的 动静 分 离 的 ， 其 动态 文件 存储 于 项 目的 根 目 录 下 ,模板 


文件 存储 于 根 目录 下 的 views 文件 夹 中 ， 而 Smarty 的 缓存 文件 和 编译 文件 则 存储 于 library\smarty 目录 下 ， 如 
图 15.12 所 示 。 


lve 
加 各 ue AD0DB 类 库 
加 fckeditor- 在 栈 篇 辑 回 


购物 车 类 
ConnDB_ php 一 一 一 一 一 数 医 库 连 接 类 
PreeDh php 一 一 一 一 一 分 页 类 
SnertyConfig php 一 一 Searty 模 板 配置 类 
Wil. php- 字符 惠 处 理 类 


图 15.12 明日 科技 图 书 网 的 类 文件 存储 位 置 


力 关键 技术 
Smarty 模板 引擎 的 配置 类 封装 在 SmartyConfig.php 文件 中 ， 其 代码 如 下 : 
require_once ‘library/smarty/libs/Smarty.class.php'; // 包 含 Smarty.class.php 文件 ， 从 而 导入 Smarty 类 库 
class SmartyConfig extends Smarty { /| 编写 SmartyConfig 类 ， 使 其 继承 自 Smarty 类 
function SmartyConfig 0{ /构造 方法 
S$this->Smarty(); // 调 用 父 类 的 构造 方法 


$arrayIni = parse_ini_file(configllzhConfigini): 。 // 解 析 lzhConfig.ini 文件 来 获取 配置 信息 
Sthis->template_dir = SarrayIni[Yemplate_dir]; /模板 文件 保存 目录 
S$this->compile_dir = $arrayIni['compile_dir]: /编译 文件 保存 目录 


S$this->cache_dir = $arrayIni['cache_dir']: /组 存 文 件 保存 目录 
S$this->config_dir = SarrayIni['config dir]: /配置 文件 保存 目录 
$this->caching = $arrayIni['caching']: /是 否 开启 视图 缓存 


本 
} 


好 技巧 : 函数 parse_ini_file0 用 于 解析 .ini 文件 ， 并 将 解析 结果 存储 到 数组 中 。 
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上 述 代 码 首 先 通过 函数 require_once0 包 含 Smarty 类 库 中 的 Smarty.class.php 文件 ， 从 而 将 Smarty 类 库 导 入 

到 工程 中 ， 然 后 定义 SmartyConfig 类 ， 使 之 继承 自 Smarty 类 ， 在 该 类 的 构造 方法 中 ， 首 先 通过 $this 关键 字 调 
用 父 类 的 构造 方法 ， 实 现 对 Smarty 模板 引擎 的 初始 化 ， 然 后 使 用 Sthis 关键 字 分 别 调用 Smarty 模板 中 的 属性 对 
模板 路 径 进行 配置 。 
图 设计 过 程 

(1) 下 载 Smarty 模板 类 库 ， 将 其 中 的 libs 文件 夹 复制 到 项 目的 library\smarty 文件 来 下 。 

(2) 在 library\smarty 文件 夹 下 创建 cache_dir、compile_dir 和 config dir 这 3 个 文件 夹 ， 用 于 存储 Smarty 
的 缓存 文件 、 编 译文 件 和 配置 文件 。 


(3) 在 library 文件 夹 下 创建 SmartyConfig.php 文件 ， 编 写 Smarty 模板 引擎 配置 类 SmartyConfig， 其 代码 
可 以 参考 关键 技术 中 的 内 容 。 


力 秘笈 心 ; 
心 法 领悟 389: 读者 需 自行 下 载 Smarty 模板 类 库 。 


由 于 Smarty 模板 类 库 属于 第 三 方 组 件 ， 所 以 在 光盘 源 程序 中 没有 提供 ， 需 要 读者 自行 下 载 ， 并 且 将 下 载 文 
件 中 的 libs 文件 夹 复制 到 项 目的 library\smarty 文件 夹 下 。 


力 实例 说 明 


在 制作 明日 科技 书店 网 站 时 , 很 多 模块 都 需要 实现 对 中 文字 符 串 的 截取 、HTML 标记 的 原样 输出 、 CKEditor 
在 线 编辑 器 的 调用 等 功能 。 为 了 提高 代码 的 重用 率 ， 可 将 上 述 功 能 封装 成 字符 串 处 理 类 。 明 日 网 上 书店 新 书 推 
荐 中 图 书 名 称 的 输出 、 图 书 价格 的 输出 ， 以 及 新 闻 公 告 中 新 闻 标 题 的 输出 都 应 用 了 字符 串 类 中 的 方法 ， 其 运行 
效果 如 图 15.13 所 示 。 
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“各 殉 和 说 , 它 分 并 了 . ， 


15.13 ”字符 串 类 中 方法 的 应 用 


力 关键 技术 


在 字符 串 处 理 类 Util 中 定义 多 个 方法 ， 分 别 实现 对 货币 格式 化 、 对 HIML 标记 进行 转 义 输出 、 对 中 文 进行 
截取 、 防 止 出 现 乱码 等 。Util 类 中 的 方法 如 表 15.1 所 示 。 
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表 15.1 Util 类 中 的 方法 列表 


方 ” 法 说 有明 
Utl0 构造 方法 ， 载 入 配置 文件 
baseUrl 0 定义 网 站 中 地 址 的 相对 路 径 
moneyFormat($money) 对 货币 进行 格式 化 。 参 数 Smoney 为 金额 
unHtml ($text) 对 HTML 标记 进行 转 义 输出 ， 参 数 Stext 为 转 义 的 文本 
Ra 对 中 文 进行 截取 ， 防 止 出 现 乱码 。 参 数 Sstr: 要 截取 的 字符 串 ，$start， 开 始 截取 的 位 置 ， 
Slen: 截取 的 长 度 
editor ($name, $value, $width ”| 集成 CKEditor 编辑 器 。 参 数 Sname: 编辑 器 名 称 ; $value: 编辑 器 内 容 ，$width: 编辑 器 
="100%'. $height 三 '200) 宽度 ; $height: 编辑 器 高 度 
editorUnHtml ($text) 转 义 编辑 器 输出 内 容 。 参 数 $text 指 输 出 内 容 
setRed ($arrayKey. Stext) 对 关键 字 描 红 。 参 数 $arrayKey: 查询 的 对 象 ，$text 查询 的 关键 字 


图 设计 过 程 
在 library 文件 夹 下 新 建 Util.php 文件 ， 封 装 字符 串 类 Util， 定 义 表 15.1 中 列 出 的 字符 串 操作 方法 。 


(1) 首先 定义 该 类 的 属性 , 充分 考虑 到 项 目 在 生产 环境 下 的 维护 工作 , 将 类 的 常用 配置 都 写 入 lzhConfig.ini 
文件 ， 所 以 该 类 的 属性 只 需要 一 个 用 来 保存 配置 文件 信息 的 数组 即 可 ， 代 码 如 下 : 


var Sarraylni; /用 于 保存 lzhConfigini 配置 文件 的 配置 信息 
(2) 定义 工具 类 的 构造 方法 。 在 构造 方法 中 通过 函数 parse_ini_file0 解 析 lzhConfig.ini 配置 文件 ， 实 现代 
码 如 下 : 
function Util O{ 
Sthis->arrayIni = parse_ini_file('config/lzhConfig.ini"); // 解 析 配 置 文 件 ， 并 将 结果 保存 到 数组 中 


} 

(3) 一 般 情况 下 ， 项 目 在 开发 环境 和 生产 环境 下 的 根 目录 是 不 同 的 ， 如 果 开发 过 程 中 采用 相对 路 径 ， 改 动 
较 小 ， 如 果 使 用 绝对 路 径 ， 那 么 所 有 涉及 路 径 的 模块 在 正式 发 布 项 目 时 都 需要 改动 。 为 了 解决 上 述 问题 ， 可 以 
将 项 目 根 目录 在 lzhConfig.ini 文件 中 指定 ， 然 后 在 需要 使 用 项 目 路 径 的 模块 中 读 取 配 置 文件 所 指定 的 项 目 根 目 
录 即 可 ， 这 里 获取 项 目 根 目录 应 用 的 是 baseUrl0 方 法 ， 代 码 如 下 : 


function baseUrl O{ 
SarrayIni = $this->arrayIni: 
return $arrayIni[baseUrl]; // 将 配置 文件 中 的 网 站 根 目录 返回 


(4) 作为 电子 商务 类 网 站 ， 项 目的 很 多 模块 中 都 需要 实现 对 货币 金额 的 格式 化 输出 ， 为 了 简化 操作 ， 在 字 
符 串 类 中 定义 moneyFormat0 方 法 ， 其 代码 如 下 : 


function moneyFormat ($money){ 
return str_replace(",, ". number_format($money, 2)): // 返 回 中 文 货币 格式 


} 
利用 moneyFormat0 方 法 首先 通过 函数 number_format0 将 金额 保留 2 位 小 数 后 格式 化 输出 ,然后 将 格式 化 后 
高 位 的 “,” 蔡 换 为 室 ， 最 后 将 处 理 结果 返回 。 


(5) 为 了 保持 所 录入 数据 按 原 格式 输出 ， 需 要 将 一 些 特殊 字符 转 义 成 HIML 标记 ， 由 于 在 项 目的 很 多 模 
块 需要 使 用 到 该 功能 ， 所 以 将 该 功能 作为 一 个 方法 封装 到 字符 串 处 理 类 中 ， 其 代码 如 下 : 


function unHtml ($text){ 
Sstr = htmlspecialchars($text): /将 特殊 字符 替换 成 HTML 转 义 标记 
$str=str_replace(chr(13)."<br>".$str): /将 换行 蔡 换 成 标记 <br> 
Sstr = nl2br($str); // 在 每 个 新 行 前 加 入 HTML 换行 标记 <br/> 
S$str=str_replace(chr(32)."&nbsp:".$str); /将 空格 蔡 换 成 标记 $nbsp: 
Teturn $str; // 返 回 处 理 后 的 字符 串 


} 
(6) 使 用 PHP 提供 的 函数 substr0 截 取 中 文字 符 会 导致 截取 乱码 ， 而 且 在 制作 项 目 时 ， 很 多 模块 都 需要 对 
过 长 的 字符 进行 截取 ， 所 以 在 字符 串 处 理 类 中 定义 msubstr0 方 法 ， 对 中 文字 符 进 行 截取 ， 其 代码 如 下 : 
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fanction msubstr ($str, $start, $len){ 
Sstrlen = $start + $len; 
for ($i=0; $i< $strlen: $i ++) { 
ff(ord(substr($str, $i, 1)) > 0xa0) { 
Stmpstr .= substr($str, $i, 2): 
Si++; 
} else 
Stmpstr = substr($str, $i, 1): 
} 
Tetum $tmpstr; 
} 


/获取 截取 字符 长 度 

// 遍 历 所 有 字符 

// 判 断 是 否 为 中 文字 符 

// 如 果 是 中 文 则 截取 2 个 字 节 


/不 是 中 文 则 截取 1 个 字 节 
/返回 结果 


(7) 使 用 HTML 语言 提供 的 文件 域 对 文本 进行 编辑 。 实 现 文本 特效 较 复杂 ， 而 且 不 能 达到 “所 见 即 所 得 ” 
的 效果 ， 为 了 解决 上 述 问题 ， 在 进行 Web 项 目 开 发 时 ， 一 般 使 用 CKEditor 在 线 编辑 器 作为 表单 的 文本 编辑 域 。 
在 制作 明日 科技 书店 时 会 在 很 多 模块 使 用 线 编辑 器 , 所 以 在 开发 时 将 调用 CKEditor 编辑 器 的 代码 封装 在 Util 字 


符 串 处 理 类 中 ， 具 体 代码 如 下 : 
function editor ($name, $value, $width ='100%', Sheight='200){ 

require_once ibrary /fckeditor /fckeditor.php': 
SarrayIni = $this->arrayIni; 
S$oFCKeditor = new FCKedit 
SFCKeditor >BasePath = $arrayIni['baseUrl'] . /library/fckeditor/'; 
S$oFCKeditor->Width = $width:; 
SoFCKeditor->Height = $height:; 
S$oFCKeditor->ToolbarSet= ' Default': 
S$oFCKeditor->Value= $value; 
S$oFCKeditor->Create0; 


// 导 入 CKEditorr 类 库 
// 获 取 配 置 文件 内 容 
/实例 CKEditor 

// 设 置 CKEditor 路 径 
/| 编辑 器 的 宽度 

// 编 辑 器 的 高 度 

1/ 设置 工具 栏 样式 
// 初 始 值 

// 创 建 编辑 器 


} 
(8) 完成 Util 类 的 封装 ， 在 lzh.inc.php 文件 中 应 用 Smarty 中 的 register_object0 方 法 将 其 注册 为 模板 对 象 ， 
在 模板 页 中 通过 模板 对 象 调用 类 中 方法 实现 对 字符 串 的 操作 。 
在 lzh.inc.php 文件 中 不 只 实现 注册 模板 对 象 的 功能 ， 所 有 类 的 实例 化 操作 都 在 该 文件 中 完成 ， 并 返回 实例 
化 对 象 ， 包 括 数据 库 连 接 类 、 数 据 库 操 作 类 、 分 页 类 和 Smarty 配置 类 ， 其 代码 如 下 : 


<2php 
session_start(); 

SarrayIni = parse_ini_file('config/lzhConfig.ini’); 
require_once ‘library/ConnDB.php'; 
require_once ‘library/AdminDB.php'; 
require_once "library/PageDB.php'; 

require_once ‘library/SmartyConfig.php'; 
require_once library/Cart.php'; 

require_once ‘library/Util.php’; 


// 初 始 化 SESSION 变量 
// 包 含 配置 文件 

// 载 入 数据 库 连接 类 文件 
// 载 入 数据 库 操作 类 文件 


// 载 入 字符 串 处 理 类 文件 


SconnDB = new ConnDB($arrayIni[' dbType'] ,SarrayIni[host] .SarrayIni[userName'] .SarrayIni['password'] ,SarrayIni['dbName'] ,SarrayIni['isDebug’]);: 


$connID = $connDB->getConnID(): 

SadminDB = new AdminDBO: 

SpageDB = new PageDB0; 

Ssmarty = new SmartyConfig(); 

Sutil = new UtilO: 
$smarty->register_object(util'. $util, null, false): 


// 执 行 与 数据 库 的 连接 
/| 数据 库 操作 类 实例 化 
// 分 页 类 实例 化 
//Smarty 配置 类 实例 化 
/| 字符 串 操作 类 实例 化 
// 注 册 模板 对 象 


(9) 在 index.php 文件 中 ， 调 用 数据 库 操作 类 中 的 方法 ， 查 询 出 数据 库 中 的 数据 ， 并 且 将 查询 结果 赋 给 模 


板 变量 ， 最 终 指定 模板 页 。 
(10) 在 模板 页 views\index.phtml 中 ， 


用 字符 串 类 中 的 方法 对 输出 的 图 书 标题 、 图 书 价格 和 公 


{section name=rID loop=$reads} 
<div style="width:198px: padding-bottom: 7px"> 
<div style="width:100%: height:90px"> 
<div style="width:85px: height:100px: float:left"> 


应 用 section 语句 循环 输出 模板 变量 中 的 数据 ， 并 且 通 过 注册 对 象 调 
告 标题 等 进行 格式 化 操作 ， 其 关键 代码 如 下 : 


<a href=" {util->baseUrl}/bookinfo-{$reads[rID].bookid} html"><img sre="{$system[0].bookimgurl}/ {S$reads[rID].bookimg}" 


width="70" height="90" style="border: lpx solid #123456" /></a> 
</div> 


<div style="width:112px: height:100px: floatright text-align:left"> 
<li style="display:inline: height:35px"><a href=" {util->baseUrl} /bookinfo-{S$reads[rID].bookid} html" class="a6">* {util->unHtml 


p=$reads[rID].bookname} </a></li> 
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i style="display:inline: line-height:20px"> 
<br 市场 价 ，&nbsp:<s> {util->moneyFormat p=S$reads[rID].oldprice}&nbsp: 元 </s> 
<br><font color="#FF0000"> 明 日 价 ，&nbsp; {util->moneyFormat p=Sreads[rID]newprice}&nbsp: 元 </font> 
<br /><a href=" {$system[0] readurl} /download.php?rid={S$reads[rID] readid} &filename={$reads[rID] filename}" 
class="a3"><img sre=" {util->baseUrl}/img/button_sd.gif" border="0"></a> 
<> 


<div style="width:100%; height30px: text-align:left; padding:3px"> futil->unHtml p=$reads[rID].aboutltruncate:88:"..."-false} </div> 
<ldiv> 
{/section} 


心 法 领悟 590: 设置 网 址 中 相对 路 径 的 方法 baseUrl0。 

在 本 实例 中 ， 所 有 文件 的 相对 路 径 都 是 通过 字符 串 类 Util 中 的 baseUrl0 方 法 来 指定 的 。 运 行 本 实例 时 还 要 
注意 , 数据 库 中 tb_system 表 中 路 径 字 段 的 设置 必须 与 程序 在 服务 器 中 的 路 径 相 互 对 应 ， 否 则 在 运行 程序 时 有 些 
图 片 或 文件 将 不 能 输出 。 


中 级 | 
实例 : 
se ee oa 
图 实例 说 明 

为 了 统一 项 目 页 面 风格 ， 提 高 代码 的 重用 率 ， 便 于 对 网 站 页 面 的 更 新 和 维护 ， 通 常 将 网 站 的 头 文件 和 尾 广 
件 进行 单独 存储 ， 在 应 用 时 通过 include 语句 包含 即 可 。 本 项 目 中 的 头 文件 和 尾 文件 就 是 作为 单独 的 文件 进行 存 
储 ， 然 后 通过 include 语句 进行 包含 。 明 日 科技 图 书 网 头 文件 的 运行 效果 如 图 15.14 所 示 。 


NNT i WR EE Rl NR TI 


| 长 明日 可 接 区 首页 。 靳 书香 价 。 由 天 。 出 书 试 丰 
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15.14 ”网 站 头 文件 的 运行 效果 


力 关键 技术 


(1) 包含 头 文件 应 用 的 是 include 语句 ， 包 含 配置 文件 应 用 的 是 require_once 语句 。 
(2) 获取 返回 路 径 中 文件 名 称 应 用 的 是 basename0 函 数 ， 其 语法 如 下 : 


string basename ( string path [, string suffix] ) 

参数 说 明 : 

path: 必 选 参数 ， 指 定 文件 的 路 径 。 

suffix: 可 选 参数 ， 如 果 文 件 路 径 以 suffix 结尾 ， 这 部 分 也 将 被 去 掉 。 


好 技巧 : 在 Windows 中 ,锋线 (/) 和 反 锋 线 (\) 都 可 以 作为 目录 分 隔 符 ， 在 其 他 环境 下 必须 使 用 儿 线 (/) 。 


(3) 应 用 switch 语句 ， 根 据 文件 名 称 定义 页 面 中 标题 的 内 容 。 
(4) 应 用 Smarty 中 的 register function() 方 法 注册 模板 函数 ， 获 取 图 书 中 类 别 的 ID 值 。 
(5) 根据 获取 的 文件 名 称 进行 判断 ， 为 变量 $dh 赋值 并 且 将 变量 值 传递 到 模板 页 。 


力 设计 过 程 
(1) 新 建 headerphp 文件 ， 包 含 配置 文件 ， 定 义 头 文件 中 的 内 容 并 且 指 定 模板 页 ， 其 关键 代码 如 下 : 
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<php 
Tequire_once ‘lzh.inc.php'; // 包 含 类 的 实例 化 文件 
SrequestPageName = basename ( $ SERVER ['PHP SELF]): 1/ 获取 当前 文件 的 名 称 
switch ($requestPageName) { // 根 据 当 前 文件 的 名 称 定义 页 面 的 标题 
case ‘index.php' : 

$title =' 明 日 网 上 书店 - 国内 信誉 一 流 的 IT 类 图 书 网 上 专营 店 ， 最 全 面 、 最 资深 的 网 上 书店 ! '; 

break; 
case bookinfo.php': 


Stopbookinfo = $adminDB->executeSQL("select bookname from tb_bookinfo where id=".$_GET['bid].™", $connID): 
S$title =' 明 日 网 上 书店 -'.$topbookinfo[O][bookname]; 
break: 

case "listbook.php': 
Stopsmalltypeinfo = $adminDB->executeSQL("select typename from tb_smalltype where id=".$_GET['stid]."", SconnID): 
$title =' 明 日 网 上 书店 -，. $topsmalltypeinfo[0]['typename'] .， 类 图 书 ': 


break; 
case ‘listsepbook.php': 
S$topt = $_GET[t]: 
if($topt — ‘new){ 
Stitle =' 明 日 网 上 书店 - 新 书 推荐 
} 
/省 略 了 部 分 代码 
Ssmarty->assign('title’, $title); // 将 标题 的 内 容 赋 给 模板 变量 
ifisset($_SESSION[unc]) && $_SESSION[unc]'="){ /判断 当前 用 户 是 否 为 空 
Ssmarty->assign('isLogin', T"); // 如 果 当 前 用 户 不 为 空 ， 则 为 模板 变量 赋值 
S$smarty->assign('une', $_SESSION[unc]); // 并 且 将 当前 用 户 名 称 赋 给 模板 变量 
} 
function getSidByBid(Sparams){ // 创 建 自 定义 函数 
extract($params); 
global $adminDB, SconnID; // 定 义 变量 范围 
$stype = $adminDB->executeSQL("select id from tb_smalltype where bigtypeid=".$bid." order by addtime limit 0, 1", $connID); 
return $stype[0][id]: 1/ 获取 攻 值 
} 
S$smarty->register_function('getSidByBid', ‘getSidByBid’); // 注 册 模 板 函 数 
SbigtypeDhs = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime". SconnID); /执行 查询 操作 
S$smarty->assign('bigtypeDhs', $bigtypeDhs): // 将 查询 结果 赋 给 模板 变量 
if($requestPageName 一 'index.php){ // 根 据 当前 文件 名 称 为 变量 $db 赋值 
Sdh = "index'; 


jelseif ($requestPageName 一 ‘listsepbook.php'){ 
if($_GET[t] — new){ 
$dh= mew': 
}elscif ($_GET[+] = 
$dh='sepprice'; 
}elscif ($_GET['t] = hotsell){ 
$dh = hotsell'; 
yelseif ($_GET[t] — "term){ 
$dh= term’; 


‘sepprice){ 


1! 
}elseif ($requestPageName 一 ‘listreadbook php){ 


Sdh = "listread': 

} 

Ssmarty->assign('dh', $dh): // 将 变量 值 传递 到 模板 变量 
if($requestPageName 一 'search php){ 


这 $_GET[stype] = 'simple){ 
Skeytxt = urldecode(str_replace('@'. %'. $_GET[keyWord"]): 
jelseif ($_POST['stype] = ‘simple){ 
Skeytxt = $_POST[keyWord]: 
上 
Ssmarty->assign(keytxt’, Skeytxt); 
Ssmarty->display ( header phtml): // 指 定 模板 页 
(2) 创建 模板 页 views\header.phtml， 设计 网 站 头 文件 的 页 面 ， 输 出 模板 变量 中 传递 的 数据 ， 其 代码 请 参考 


本 书 光盘 ， 这 里 不 再 疯 述 。 
国 秘笈 心 法 
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包含 文件 是 指 将 另 一 个 文件 中 的 内 容 包含 到 当前 文件 中 。 包 含 外 部 文件 可 以 提高 代码 的 重用 率 ， 是 PHP 编 
程 的 重要 技巧 。PHP 提供 了 include、require、include_once 和 require_once 语句 用 于 实现 包含 文件 操作 。 

使 用 require 语句 调用 文件 时 ， 如 果 调 用 的 文件 没 找到 ，require 语句 会 输出 错误 信息 ， 并 且 立 即 终止 脚本 的 
处 理 。 而 include 语句 在 没有 找到 文件 时 会 输出 警告 ， 但 不 会 终止 脚本 的 处 理 。 

使 用 require 语句 调用 外 部 文件 时 ， 只 要 程序 一 执行 就 会 立刻 调用 ;而 使 用 include 语句 时 ， 只 有 程序 执行 
到 该 语句 时 才 会 调用 外 部 文件 。 


级 1 
力 实例 说 明 
明日 科技 图 书 网 尾 文件 也 是 作为 单独 的 文件 进行 存储 的 ， 其 运行 效果 如 图 15.15 所 示 。 


订 香 站 名 尽 最 运 a 
， 工作 在 支付 ， 地 市 渤 竟 上 门 
闻 H 宇 


图 书 。 | 乱弹 向 | 技术 论 王 | 半 员 掉 南 
wpyriaht 生长 有 曙 和 持 情 古 1899-2010，A1 dhts Inservedl IC 部 TD812945 


图 15.15 网 站 尾 文件 的 运行 效果 


力 关键 技术 


网 站 尾 文件 在 输出 各 种 超 链接 的 同时 还 输出 数据 库 中 tb_system 表 的 数据 ， 其 存储 的 是 项 目的 系统 信息 。 
tb_system 表 的 结果 如 图 15.16 所 示 。 

在 运行 明日 科技 图 书 网 的 程序 时 ， 要 对 tb_system 表 中 readurl、bookimgurl 和 ggurl 这 3 个 字段 的 值 进行 修 
改 ， 以 设置 正确 的 程序 路 径 ， 如 图 15.17 所 示 。 


图 服务 器 :ecalhost 》 配 数据 库 : db_database15 》 回 表 :tb_system 
本 度 人 整理 是 Ru 祝 外 
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图 15.16 明日 科技 图 书 网 的 系统 表 结 果 图 15.17 设置 程序 在 服务 器 中 的 相对 路 径 


笔者 在 开发 本 项 目 时 ， 将 其 存储 于 Apache 服务 器 的 mr/15/005 文件 夹 下 。 读 者 在 运行 程序 时 ， 需 要 根据 自 
己 的 实际 情况 对 这 个 路 径 进 行 修改 。 


图 设计 过 程 
(1) 新 建 footer.php 文件 ， 读 取 项 目 系统 表 tb_system 中 的 数据 并 且 将 数据 存储 到 模板 变量 中 ， 同 时 指定 
模板 页 ， 其 代码 如 下 : 
<2php 


PHP 开发 实例 大 全 (基础 卷 ) 


S$systemBottom = $adminDB->executeSQL("select bq, icp from tb_system where mark = 1". $connID): 
S$smarty->assign('systemBottom', $systemBottom):; 

Ssmarty->display('footer.phtml’); 

$connDB->closeConnID(); 


(2) 在 views 文件 夹 下 新 建 footer.phtml 模板 文件 ， 输 出 模板 变量 中 存储 的 系统 信息 ， 同 时 创建 常用 功能 
的 超 链 接 ， 其 代码 请 参考 本 书 光盘 。 


心 法 领悟 392: 应 用 require_once 语句 包含 文件 。 

require_once 语句 是 require 语句 的 延伸 ， 其 功能 与 require 语句 基本 类 似 ， 不 同 的 是 ， 在 应 用 require_once 
语句 时 会 先 检查 要 包含 的 文件 是 不 是 已 经 在 该 程序 中 的 其 他 地 方 被 包含 ， 如果 是 ， 则 不 会 再 次 重复 调用 该 文件 。 

include_once 语句 和 require_once 语句 的 用 途 是 确保 一 个 被 包含 文件 只 能 被 包含 一 次 。 使 用 这 两 个 语句 可 以 
防止 意外 地 多 次 包含 相同 的 函数 库 ， 避 免 因 函数 的 重复 定义 产生 的 错误 。 但 两 者 之 间 是 有 区 别 的 : include_once 
语句 在 脚本 执行 期 间 调用 外 部 文件 发 生 错 误 时 产生 一 个 警告 ， 而 require_once 语句 则 导致 一 个 致命 错误 。 

include_once 和 require_once 语句 在 大 小 写 不 敏感 的 操作 系统 中 (如 Windows) 的 行为 可 能 不 是 所 期 望 的 。 


" | | 
国 实例 说 明 

明日 科技 图 书 网 的 首页 中 有 一 个 循环 播放 的 广告 位 , 本 实例 实 
现 3 个 广告 的 循环 播放 , 并 且 每 个 广告 链接 不 同 的 文件 , 其 运行 效 
果 如 图 15.18 所 示 。 
图 关键 技术 


首页 广告 的 设计 应 用 的 是 js 脚本 技术 ， 控 制图 片 的 展开 方法 ， 完 成 图 片 的 循环 播放 ， 其 调用 的 是 一 个 已 经 
定义 好 的 js 脚本 lzhScrollImgjs。 
在 模板 页 中 还 要 设置 一 些 参 数 ， 关 键 代 码 如 下 : 


<script language="javascript"> 


var w="515px"; // 广 告 宽度 
varh="150px"; // 广 告 高 度 
var bg = "#99CCFF"; /广告 背 景色 
var imgSre = new Array: // 图 片 地 址 


var imgLink = new Array: // 图 片 链 接地 址 
imgLink[0] = ‘http://www.mrbooks.cn'; 

imgLink[1] = ‘http://www.mrbeed.com'; 

imgLink[2] = ‘http://www.mrbooks.cn/listsepbook-sepprice.html'; 

var imgLinkTitle = new Array: // 图 片 链接 提示 文字 


] 
imgLinkTitle[2] = 优惠 购书 '; 
</script> 
<script language="javascript" sre=" {util->baseUrl} /js/lzhSerollimg:js"></script> 


看 设计 过 程 
(1) 在 index.phtml 模板 页 中 ， 定 义 JavaScript 脚本 ,定义 广告 位 的 各 种 参数 并 且 载 入 调用 的 js 脚本 。 其 代 
码 请 参考 关键 技术 中 的 内 容 。 
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(2) 将 lzhserollimgjs 脚本 文件 存储 于 本 实例 根 目录 的 js 文件 夹 下 。 
图 秘笈 心 法 


心 法 领悟 593: js 特效 。 
读者 不 必 自 己 研究 js 脚本 特效 的 实现 方法 ， 可 以 充分 利用 网 络 资源 查找 自己 喜欢 的 特效 代码 ， 然 后 将 其 应 
用 到 自己 的 程序 中 即 可 。 


15.3 注册、 登录 


明日 科技 图 书 网 用 户 登录 模块 的 主要 功能 是 为 用 户 提供 服务 、 建 立 网 站 管理 者 和 用 户 沟通 的 桥梁 ， 主 要 包 
括 用 户 注册 、 用 户 登 录 、 用 户 注册 信息 修改 、 用 户 密码 修改 、 查 看 提交 订单 信息 和 查看 在 网 站 上 的 消费 情况 等 
功能 。 


i 中 级 | 


图 实例 说 明 


用 户 注册 模块 主要 用 于 对 用 户 注册 信息 进行 收集 ， 用 户 再 次 参与 该 站 点 活动 时 ， 通 过 登录 模块 成 功 登录 后 
即 可 参与 进来 。 用 户 注册 模块 不 仅 可 以 方便 用 户 参 与 本 站 活动 ， 而 且 也 是 对 网 站 人 气 的 积累 。 明 日 网 上 书店 的 
用 户 注册 表单 如 图 15.19 所 示 。 


得 首届 计 | 玖 基 话机 为 本 住 | 饭 作 不 先 


站 当前 的 位 置 ， 明 日 网上 书记 7》 填写 用 广 注 机 信息 


用 记名 在 : 图 日 科 扶 9 Ei : 
车 录 厂 因 : 注册 和 导 


注册 用 户 湾 近 前 协 计生 本 直 
活动 了 


图 15.19 用 户 注册 表单 


图 关键 技术 


(1) 图 片 验 证 码 。 制 作 图 片 验证 码 时 ， 首 先 通过 JavaScript 的 Math 对 象 的 random() 方 法 产生 一 个 随机 数 ， 
并 通过 Math 对 象 的 round0 方 法 截取 该 随机 数 的 前 4 位 。 然 后 再 分 别提 取 该 随机 数 的 每 一 位 ， 将 提取 的 每 一 位 
数字 通过 GET 方法 传递 到 xym.php 页 面 , 在 xym.php 页 面 中 根据 传递 过 来 的 数组 读 取 相应 的 图 片 并 将 结果 显示 
出 来 ， 其 代码 如 下 : 


PHP 开发 实例 大 全 (基础 卷 ) 


Soum=$_GET[oum]: /获得 传递 的 数字 
S$address="img/code/". $num.".gif"'; /获取 对 应 图 片 地 址 
Sfp=fopen($address."r"): // 打 开 对 应 的 图 片 

echo fread($fp.filesize($address)): /将 图 片 以 二 进 制 的 形式 输出 到 浏览 器 
felose(${p); /关闭 打开 的 图 片 


在 将 生成 的 随机 数 的 每 一 位 传递 到 xym.php 文件 的 同时 ， 将 该 随机 数 赋 给 一 个 隐藏 域 ， 这 样 在 验证 用 户 输 
入 的 验证 码 是 否 正 确 时 , 就 可 以 根据 用 户 输入 的 内 容 和 该 隐藏 域 的 value 值 进行 对 比 得 出 结果 , 如 果 二 者 相等 则 
说 明 用 户 输 入 的 验证 码 正确 。 

(2) 验证 用 户 输入 的 用 户 名 是 否 被 占用 。 

当 用 户 输入 注册 信息 时 , 应 用 JavaScript 对 用 户 输入 的 内 容 进 行 实时 验证 , 其 中 验证 用 户 名 是 否 被 占用 的 方 


法 存储 于 \js\funjs 文件 中 ， 其 代码 如 下 : 
function chkreginfo(form, mark, edit, baseUrl) { 
if((mark =— 0||mark— "all") && edit != "edit") { 


ff(form.useme.value — "") { / 漳 断 用 户 输入 的 昵称 是 否 为 空 
chkusernc.innerHTML = "请 输入 用 户 昵称 ! “: // 如 果 为 空 则 给 出 提示 
form.userne.style.backgroundColor = "#FF0000"; // 更 改 用 户 昵称 文本 框 的 背景 为 红色 
Tetum false; 

} else{ 
var xmlobj; // 定 义 XMLHttp 对 象 
if(window.ActiveXObject) { // 如 果 是 Windows 系统 

xmlobj = new ActiveXObject("Microsoft XMLHTTP"); // 通 过 ActiveXObject0 实 例 XMLHttp 对 象 
} else if (window. XMLHttpRequest) { 
xmlobj =new XMLHttpRequest(); /通过 XMLHttpRequest0 实 例 XMLHttp 对 象 
} 
xmlobj.onreadystatechange = fun: // 设 置 回调 函数 
xmlobj.open("GET"， /通过 GET 方法 向 服务 器 发 送 数据 
baseUrl + "/chkunc php?unc=" + form usemec valuc, true); 
xmlobj.send(null); 
function fun() { /定义 回调 函数 
if (xmilobj.readyState 一 4 && xmlobj.status — 200) { 
f(xmlobj.responseText — "0") { // 如 果 返 回 0 则 说 明 昵称 被 占用 


chkuseme ,innerHTML = "该 昵称 已 被 占用 ! ": 
form.usemne.style.backgroundColor = "#FF0000"; 
retum false; 

}else{ 

innerHTML = ™"; 

form.usemne.style.backgroundColor = "#FFFFFF"; 

} 

} 
} 
} 


} 
/省 略 代码 请 详 见 本 书 附带 光盘 


Teturmn true; 


} 

上 述 代码 首先 根据 不 同 浏览 器 的 类 型 生成 HTTP 请 求 对 象 ， 然 后 使 用 该 对 象 的 open( 方 法 将 用 户 输入 的 昵 
称 传递 给 chkunc.php 页 面 ， 并 根据 chkunc.php 页 面 的 返回 值 判断 用 户 输 入 的 昵称 是 否 已 经 被 占用 ， 其 中 
chkunc.php 的 关键 代码 如 下 : 


require_once ‘lzh.ine.php'; /包含 公共 类 
Sarrayunc=$adminDB->executeSQL("select iduseme from tb_user where usemc=".S_GET["unc"]."".SconnID): /查找 用 户 昵称 
if($arrayune) 

echo 0: // 如 果 查 找到 则 返回 0 
else 

echo 1; // 没 有 查 到 则 返回 1 


图 设计 过 程 
(1) 制作 用 户 注册 表单 UI 界面 。 用 户 注册 表单 除 用 户 名 和 登录 密码 等 信息 外 ， 为 了 与 用 户 进行 沟通 ， 还 


需要 用 户 的 联系 电话 、E-mail 地 址 和 邮编 等 信息 ， 据 此 编写 明日 科技 书店 的 注册 表单 ， 模 板 页 getuserinfo phtml 
的 主要 代码 如 下 : 
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<form name="form_reg" method="post" action=" {util->baseUrl}/getuserinfo.php" onSubmit="return chkreginfo(form reg.all)"> 
<table width="90%" border="0" align="center" cellpadding="0" cellspacing="0"> 
<t> 
<td width="22%" height="30"><div align="right"> 用 户 昵称 : </div></td> 
<td colspan="3">&nbsp:<input type="text" name="useme" size="20" class="input' onBlur="chkreginfo(form_reg.0., ", '{util->baseUrl})"></td> 
<td width="25%"><div id="chkuseme" style="color:#FF0000"></div></td> 
<lt> 
<tr> 
<td height="30"><div align="right"> 登 录 密码 : </div></td> 
<td height="30" colspan="3">&nbsp:<input type="password" name="userpwd1" size="25" class="input" 
onBlur="chkreginfo(form reg,1)" ></td> 
<td height="30"><div id="chkuserpwd1" style="color:-#FF0000"></div></td> 
<> 
…<!-- 此 处 省 略 部 分 表单 元 素 实现 代码 ， 请 详 见 本 书 光盘 --> 
<tr> 
<td height="30"><div align="right"> 验 证 码 :</div></td> 
<td width="17%" height="0">&nbsp;<input type="text" name="xym" size="8" class="input" onBlur="chkreginfo(form reg,12)"/><input 
type="hidden" value=" name="xym1"></td> 
<td width="12%"> 
<script language="javascript"> 
var numl=Math round(Math.randomO*10000000): 
var num=numl toString().substr(0.4); 
document write("<img name=codeimg4 sre="{util->baseUrl}/xym.php?num="+num.substr(0,1)+"&baseUrl=: 
document.write("<img name=codeimgs sre=" {util->baseUrl}/xym.php?num="+num.substr(1,1)+"&baseUrl={util->baseUrl}>"); 
document write("<img name=codeimg6 sre= {util->baseUrl} /xym.php?num="+nun.substr(2,1)+"&baseUrl={util->baseUrl}'>"); 
document.write("<img name=codeimg7 sre="{util->baseUrl}/xym.php?num="+num.substr(3,1)+"&baseUrl= {util->baseUrl}'>"); 
form_reg.xyml .value=num:; 
<!-- 该 方法 用 于 实现 重新 为 验证 码 赋值 --> 
function code_10 {ldelim} 
var num1=Math.round(Math.random()*10000000); 
var num=numl.toStringO.substr(0.4): 
document.codeimg4.sre=" {util->baseUrl}/xym.php?num="+num.substr(0,1)+"&baseUrl={util->baseUrl}"; 
document.codeimg5.sre=" {util->baseUrl} /xym.php?num="+num. substr(1,1)+"&baseUrl= {util->baseUr}"; 
document.codeimg6.sre=" {util->baseUrl}/xym.php?num="+num.substr(2,1)+"&baseUrl={util->baseUrl}"; 
document.codeimg7.sre=" {util->baseUrl}/xym.php?num="+num.substr(3,1)+"&baseUrl= {util->baseUrl}"; 
form reg.xyml .value=num; 
{rdelim} 
</script></td> 
<td width="24%"><a href="javascript:code_10" class="a1"> 看 不 清 </a></td> 
<td height="0"><div id="chkxym" style="color:-#FF0000"></div></td> 
</tr> 
<tr> 
<td height="40" colspan="5"><div align="center"> 
<input type="submit" value=" 立 即 注册 " class="btn_grey"> 
<input type="reset" value=" 重 置 " class="btn_grey"> 
<ldiv> 
<ltd> 
</t> 
</table> 
</form> 


(2) 当 用 户 输入 注册 信息 时 ， 应 用 JavaScript 对 用 户 输入 的 内 容 进行 实时 验证 ， 其 JavaScript 脚本 存储 于 
Wisfunjs 文件 中 ， 完 整 代码 请 参考 本 书 光盘 。 

(3) 用 户 输入 的 内 容 成 功 通过 数据 有 效 性 验证 后 ， 所 有 输入 的 内 容 将 被 提交 到 getuserinfo.php 页 面 进行 保 
存 ， 其 关键 代码 如 下 : 


util->baseUrl} >"); 


require_once header.php’; // 包 含 header.php 文件 
if(isset($_POST["useme"]) && $_POST["useme"] (= "") { 1/ 判断 是 否 提 交 了 表单 
f(! $adminDB->executeSQL("select id, useme from tb_user where usemc=" .$_POST["userme"] . "", $connID)) { // 判 断 昵称 是 否 被 占用 
Stime = date("Y-m-d H:i:s"); /获取 注册 时 间 


if($adminDB->executeSQL("insert into 
tb user(useme,truename.pwd.email.sex.tel.qq.address.logintimes.regtime.lastlogintime .ip.yb.usertype.answer.question,truepwd.photo.score) values(". 
$_POST["useme"] . ww" . $_POST["truename"] . "," . md5(trim($_POST["userpwd1"]) . "." . $_POST["email"] ."," . $_POST["sex"] . "." 
$_POST["tel"] . "." .$_POST["qq"] .".".$ POST["address"] . "0'$time','$time',”" . $_SERVER[REMOTE / ApDR] we" $ POST["yb"] . 
$_POST["answer"] .wm . $_POST["question"] . www . trim($_POST["userpwd1"]) .www . "img/face/" . $_POST["photo"] . ".30)", $connID)) { 
1/ 保存 用 户 的 注册 信息 
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让 (isset($_SESSION["unc"]) &é& $_SESSION["unc"] = "") { 
unset($_SESSION["une"]): 


3 1/ 销毁 原来 登录 用 户 的 登录 昵称 
session_register("unc"); // 注 册 新 的 用 户 昵称 到 SESSION 变量 
$_SESSION["une"] = trim($_ POST["usemc"]): 
让 (isset($_SESSION[toUrl]D) { /获取 要 跳 转 的 页 面 ， 并 进行 跳 转 
echo "<script>window .location href=" . Sutil->baseUrlO . "/" .$_SESSION[toUd] . ™;</seript>"; 
}else{ 


echo "<script>window .location href=" . Sutil->bascUrlO . "/regsuccess html';</script>"; 
则 

} else{ 
echo "<seript>alert( 注 册 失败 ， 请 重 试 ! )</script>": 


}else{ 
echo "<script>alert(' 该 昵称 已 经 被 他 人 注册 ! ")</script>"; 
} 
} 
Ssmarty->display('getuserinfo.phtml"): 
require_once ‘footer.php'; 


国 秘笈 心 ; 


心 法 领悟 594: 防止 用 户 越过 表单 限制 上 传 数据 。 

在 本 实例 的 getuserinfo .php 文件 中 , 为 了 避免 由 于 用 户 的 浏览 器 禁用 JavaScript 脚本 功能 而 使 用 户 输入 昵称 
的 唯一 性 验证 失效 ， 或 者 某 些 用 户 越过 表单 的 验证 机 制 直接 上 传 数据 ， 在 保存 用 户 提交 的 注册 信息 前 ， 首 先 使 
用 数据 库 管理 类 的 executeSQLO 方 法 查询 是 否 存在 和 用 户 提交 昵称 相同 的 注册 用 户 ， 如 果 存 在 则 提示 该 昵称 已 
被 占用 ， 并 返回 注册 页 面 要 求 用 户 重新 填写 注册 信息 ， 反 之 则 将 用 户 提交 的 注册 信息 保存 到 数据 库 中 。 


力 实例 说 明 


用 户 在 明日 科技 图 书 网 购买 图 书 时 , 需要 首先 登录 | Ou 
站 点 ,这 样 可 以 记录 购买 人 信息 ,并且 可 在 用 户 中 心 的 二 rns 
订单 查询 模块 中 查询 到 该 用 户 的 所 有 订单 信息 。 明日 科 ee ame emt | 
技 图 书 网 的 用 户 登 录 页 面 如 图 15.20 所 示 。 es rm | 


ER 要 中 


关键 技术 15.20 用户 登 录 页 面 


登录 的 目的 就 是 为 用 户 开 据 一 张 通行 证 ， 使 其 可 以 在 网 站 中 进行 任意 操作 (权限 范围 之 内 ) ， 也 是 其 行使 
网 站 会 员 权 限 的 依据 。 而 这 个 通行 证 的 开 据 应 用 的 是 SESSION 技术 。 登 录 成 功 后 ， 将 用 户 名 存储 到 SESSION 
变量 中 ， 即 完成 通行 证 的 开 据 ， 其 代码 如 下 : 
$_SESSION[unc] = $useme: 
< 仙 注 意 : 在 应 用 SESSION 变量 之 前 , 切记 一 定 要 应 用 session_start0 函 数 初始 化 SESSION 变量 ， 否 则 SESSION 
变量 不 能 使 用 ,并 且 在 应 用 session_ start0 函 数 之 前 不 能 有 任何 输出 。 本 实例 中 SESSION 变量 的 初始 
化 操作 是 在 包含 文件 1zh.inc.php 中 完成 的 。 


该 功能 利用 SESSION 可 以 在 页 面 之 间 传 递 数据 的 特性 ， 确 保 这 个 通行 证 在 网 站 的 任意 一 个 页 面 中 都 有 效 ， 
直到 用 户 退 出 登录 。 
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图 设计 过 程 
(1) 在 views 文件 夹 下 创建 login.phtml 登录 表单 的 UI 界面 ， 其 实现 方法 与 注册 表单 类 似 ， 这 里 不 再 次 述 。 


(2) 当 用 户 单 击 “ 登 录 ” 按 钮 后 ， 将 对 用 户 输入 的 用 户 名 、 密 码 和 验证 码 进 行 有 效 性 验证 ， 如 果 验 证 通过 
则 将 用 户 输入 的 数据 提交 到 login php 中 进行 处 理 ， 关 键 代码 如 下 : 
<Iphp 


让 (isset($_ POST[usemc]) && $_ POST[usemc] (=") { // 判 断 是 否 提交 了 表单 
$usernc =trim($ POST[usemc]): /获得 提交 的 用 户 名 
$pwd=trim($ POST[usempwd]): // 获 得 提交 的 登录 密码 
Suser = $adminDB->executeSQL("select id, userne from tb_user where usemc=" . Suseme . " and pwd=" . md5($pwd) . "", $connID); // 按 用 户 名 
和 密码 查询 用 户 
if(! $user) { 
SerrorMsg =' 用 户 名 或 密码 输入 有 误 ! '; 
}else{ 
if(isset($_SESSION["une"])) { /销毁 原 登录 用 户 信息 ， 并 注册 新 登录 用 户 信息 给 SESSION 变量 
Session_unregister(unc'); 


} 
$ SESSION[f'unc'] = $userme; 
@$adminDB->executeSQL("update tb_user set logintimes=logintimes+1 ,lastlogintime =" . date('Y-m-d H:i:s) . ",ip=" . 
$_SERVER[REMOTE_ADDR'] .™" where usemc=" .$_ SESSION[unc] ."", $connID); /更 改 用 户 的 登录 信息 
if(isset($ SESSIONTYoUrlTD) { 
echo "<script>window ,location href=" . Sutil->baseUrlO . "/" .$_SESSION[YoUd] .";</seript>"; 


echo "<script>window location href=" . Sutil->baseUrlO . "/usercenter.html';</script>"; 
exitO; 


} 
人 S$errorMsg); 
Ssmarty->display(login.phtml9; 
require_once ‘footer.php'; 
上 述 代码 中 ， 首 先 定义 变量 gerrorMsg， 保 存 处 理 登 录 表 单 提交 数据 时 出 现 的 错误 信息 〈 例 如 登录 失败 信息 
等 ) ， 然 后 使 用 $_POST 全 局 数组 接收 用 户 提交 的 用 户 名 和 登录 密码 ， 并 使 用 数据 库 管理 类 的 executeSQL( 方 法 
执行 查询 语句 来 判断 用 户 输入 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 确 则 更 改 用 户 登 录 次 数 和 最 后 登录 时 间 ， 反 之 


则 将 登录 失败 信息 赋 给 变量 gerrorMsg， 并 传递 给 login.phtml 模板 。 
秘笈 心 法 


心 法 领悟 595: 延长 SESSION 的 生命 周期 。 

在 开发 程序 的 过 程 中 可 能 会 遇 到 这 样 的 情况 ， 以 会 员 的 身份 登录 一 个 网 站 后 ， 如 停留 的 时 间 较 长 ， 此 时 在 
这 个 网 站 中 发 布 信息 时 ， 会 提示 “您 没有 登录 ， 请 登录 后 再 发 布 信息 ”。 

之 所 以 出 现 此 类 问题 ， 就 是 因为 在 登录 时 定义 的 SESSION 变量 已 经 过 期 ， 导 致 当前 用 户 不 可 用 ， 需 要 重新 
登录 。 解 决 这 个 问题 最 好 的 方法 就 是 通过 session_set_cookie_params0 函 数 延 长 SESSION 的 生命 周期 , 将 过 期 时 
间 设 置 为 0。 


A 高 级 | 
实例 596 趣味 指数 : 相机 本 办 | 
实例 说 明 


明日 科技 图 书 网 的 用 户 中 心 ， 主 要 用 于 实现 对 用 户 注册 信息 和 用 户 登 录 密码 的 修改 、 用 户 订单 的 查询 和 意 
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见 的 反馈 等 操作 ， 其 页 面 运行 效果 如 图 15.21 所 示 。 


全。 St ZE 天时 日 间 上 书后 ws 双生 吾 杂 ] 。。 国 晶 因 二 排 生 ”天 铺 书 条 [各 内 ] 


| 长 雪 而 明日 对 芒 书 店 


Wmrbooks.cm 


首页 新 蔬 特价 。 起 表 


图 15.21 用 户 中 心 


力 关键 技术 


在 用 户 中心 或 者 后 台 管理 模块 中 ， 都 会 应 用 到 用 户 登录 成 功 后 开 据 的 “通行 证 (SESSION 变量 ) ”， 通 过 
这 个 SESSION 判断 用 户 是 否 已 经 登录 ,如 果 没 有 登录 则 应 该 跳 转 到 首页 或 用 户 登录 页 面 , 这 样 可 以 防止 非法 用 


户 直接 通过 地 址 栏 访问 ， 同 时 在 一 定 程度 上 保护 了 后 台 管理 系统 的 安全 ， 其 关键 代码 如 下 : 
让 (lisset($_SESSION[une]) || $_SESSION[unc'] =—") // 判 断 用 户 是 否 已 经 登录 


{ 
echo "<script>alert( 禁 止 非 登 录 ! ):window ,location_ href-" . Sutil->baseUrlO . "/index.html';</script>"; // 跳 转 到 首页 
exitO; /| 终止 程序 执行 
} 
力 设计 过 程 


(1) 修改 个 人 信息 。 

会 员 登 录 成 功 后 ， 可 以 通过 用 户 中 心 的 修改 个 人 信息 模块 对 注册 信息 进行 修改 。 用 户 中 心 修改 个 人 信息 的 
表单 如 图 15.21 所 示 ， 默 认 情 况 下 ， 将 当前 登录 用 户 的 注册 信息 填充 在 用 户 信息 表单 中 。 用 户 修改 完 个 人 信息 
并 单 击 “ 更 改 ” 按 钮 ， 将 用 户 个 人 信息 数据 提交 到 usercenter.php 页 面 进行 处 理 ， 其 关键 代码 如 下 : 


require_once header.php'; 


if(! isset($_SESSION[une']) ||$_SESSION[unc] =—") { 1/ 判断 用 户 是 否 已 经 登录 
echo "<script>alert( 禁止 非 登录 ! ):window ,location_ href-" . Sutil->baseUr0 . "/index.html';</script>"; 
exit(); 

} 

if(isset($_POST['truename']) && $_POST['tuename'] (=") { // 判 断 是 否 已 经 提交 了 表单 


if (! $adminDB->exeenteSQL("update tb_nser set truename=" . $_POST['tmename] . ", sex=" . $_POST['sex] . ", tel=" . $_POST['el] ." 
email=". $ POST[email] . ", qq=" . $ POSTPaq'] . ", yb=" . $ POST['yb'] . ", address—" . $ POSTaddress1.w where usemc=" . 
$_SESSION['une’] . "", $connID)) { /修改 注册 信息 
echo "<script>alert( 用 户 信息 更 改 失败 1 )<jscript>": 


/于 新 查询 用 户 信息 

Suser = $adminDB->executeSQL("select truename, sex, tel. email, qq, yb. address from tb_user where useme=" . $_SESSION['une'] . "", $connID); 

S$smarty->assign('user', $user): 

Ssmarty->display('usercenter.phtml’); 

require_once "footerphp': 

上 述 代码 首先 判断 SESSION 变量 une 的 值 是 否 存在 ， 如 果 不 存 在 ， 则 说 明 当 前 访问 者 为 非法 登录 用 户 ， 这 
时 将 给 出 非法 登录 提示 ， 并 将 页 面 定 向 到 首页 ， 反 之 使 用 数据 库 管理 类 的 executeSQL( 方 法 更 改 用 户 信息 ， 并 
将 用 户 更 改 后 的 信息 重新 回填 到 用 户 信息 更 改 表单 。 

(2) 修改 登录 密码 。 
通过 用 户 中 心 的 修改 登录 密码 模块 可 以 对 用 户 的 登录 密码 进行 修改 ， 用 户 密码 修改 表单 包括 原 密码 录入 文 
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本 框 、 新 密码 录入 文本 框 和 确认 密码 录入 文本 框 3 个 表单 元 素 ， 如 图 15.22 所 示 。 
系统 将 用 户 修改 的 数据 提交 到 usercenterchangepwd.php 页 面 ， 在 该 页 面 中 完成 对 密码 的 更 改 。 首 先 判断 用 
户 是 否 非法 登录 ， 然 后 判断 用 户 输入 的 原 密码 是 否 正 确 ， 如 果 正 确 则 将 用 户 密码 更 改 成 新 值 ， 反 之 给 出 错误 提 


示 ， 其 代码 如 下 : 

<?php 

require_once ‘header.php'; 

if(! isset($_SESSION['une']) 1 $_SESSION[unc] 一 "){ // 判 断 用 户 是 否 已 经 登录 
echo "<script>alert( 禁止 非 登 录 ! ");window.location href=". Sutil->baseUrlO . "/index.html';</script>"; 
exit0; 

} 

让 (isset($_ POST[oldpwd]) && $_POST['oldpwd] =") { // 判 断 用 户 是 否 已 经 提交 了 表单 
证 (! $adminDB->executeSQL("select id, useme from tb_user where useme=" .$_SESSION[unc] . " and pwd=" .mds($_ POST[oldpwd]) .™", 

E00 . 

echo "<script>alert(' 原 密码 输入 有 误 ! ");</script>"; // 验 证 原 密 码 是 否 正确 


} else{ 
ff ($adminDB->executeSQL("update tb_user set pwd=" .mds($_ POST[pwdl]) . ". truepwd=" .$_ POST[pwdl] . " where usernc=" . 
$_SESSION['unc'] . ™", $connID)) { // 执 行 更 改 密码 操作 
echo "<script>alert(' 密 码 更 改 成 功 ! ");</script>"; 
jelse{ 
echo "<script>alert(' 密 码 更 改 失败 ! ");</script>"; 
} 
} 


Cn 
require_once ‘footer.php’; 
(3) 意见 反馈 。 

用 户 在 参与 本 站 活动 时 ， 如 果 对 网 站 的 管理 或 运营 存在 建议 或 意见 ， 可 以 通过 用 户 中 心 的 意见 反馈 模块 将 
个 人 意见 提交 给 网 站 管理 者 。 明 日 科技 图 书 网 的 意见 反馈 表单 如 图 15.23 所 示 。 
ec 
ME: 2 Pt 并 且 记 用 FHF 化 焰 名 
新 神思 | 对 您 使 用 的 拉 术 间 常 隔 兴 施 ， 芒 所 和 不 训 唱 


对 ER | 


| EE 加 | EE PO i 
图 15.22 用 户 密码 修改 表单 图 15.23 用 户 意见 反馈 表单 


用 户 填写 的 反馈 意见 将 被 提交 到 userfeedback.php 页 面 ， 在 该 页 面 中 应 用 数据 库 管理 类 中 的 executeSQLO 
方法 将 反馈 意见 添加 到 tb_feedback 数据 表 中 ， 其 代码 如 下 : 


if(! isset($_SESSION['unc']) | $_SESSION[une] —") { // 判 断 用 户 是 否 已 经 登录 

echo "<script>alert(' 禁 止 非 登 录 ! '):window.location.href=" . Sutil->baseUrlO . "/index.html';</script>"; 

exit0: 
} 
if(isset($_POST['title']) && $_POST['title] =") { a 

if (SadminDB->executeSQL("insert into tb_feedback(title. eontent, addtime useme) values(" . $_POST['title] . ". ". $_POST[eontent] . ", " . 
date(Y-m-d Hii's) . ". " . $_SESSION['une'] . ")", $connID)) { /保存 用 户 的 反馈 意见 信息 

echo "<script>alert( 你 的 反馈 信息 已 经 成 功 保存 ， 谢谢 您 的 支持 ! ");</script>"; 
}else{ 


echo "<script>alert( 反 馈 信息 保存 失败 ， 请 重 试 ! );</script>"; 
2. 
} 


力 秘笈 心 法 


心 法 领悟 596: 用 户 中心 功 能 总 结 。 

在 用 户 中 心 功能 模块 中 应 用 的 技术 可 以 划分 为 两 部 分 : 第 一 部 分 ， 在 Smarty 模板 页 中 创建 form 表单 ， 提 
交 用 户 需 要 更 新 的 数据 ; 第 二 部 分 , 在 PHP 动态 页 中 , 应 用 数据 库 管理 类 中 的 executeSQLO 方 法 执行 select\insert 
和 update 语句 ， 完 成 对 用 户 的 验证 、 数 据 的 添加 和 更 新 操作 。 
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起 味 指教 : 广 丰 让 容 


力 实例 说 明 


明日 科技 图 书 网 中 ，“ 我 的 订单 ”只 是 用 户 中 心 功能 模块 中 的 一 个 子 模块 ， 其 功能 是 输出 当前 登录 用 户 的 
订单 信息 ， 同 时 可 以 查看 订单 的 详细 信息 ， 执 行 取消 订购 和 确认 收 货 的 操作 ， 其 运行 效果 如 图 15.24 所 示 。 


CN 
oo 
二 :DIE 通 
修业 性 ;吉村 党 长丰 [ 生 于 广场" 怀 ?2v 旦 


本 Wa ERACR) Mma Nit 
rm 开放 大 型 醒 块 大 全 》 To-og To 2 as om 
(ri pe-og 。。 殉 0 1 9 00 
Et .00 元 
玫 界 : 30.00 元 
Re 而 267 00 元 
可 有 杖 者 【Pt 宁 : 同 。 忆 共 ; 网 已 必 性; 同 ] 取消 订购 确认 和 各 


图 15.24 我 的 订单 功能 展示 


图 关键 技术 


在 开发 “我 的 订单 ”功能 模块 时 ， 应 用 的 技术 如 下 : 
(1) 数据 库 的 连接 、 操 作 类 。 
(2) Smarty 模板 引擎 的 配置 类 。 
(3) 字符 串 的 处 理 类 ，baseUrl0 方 法 获取 网 址 的 相对 路 径 ，moneyFormat0 方 法 对 货币 金额 进行 格式 化 ， 
unHtml0 方 法 对 HTML 字符 串 进行 转 义 。 
(4) 应 用 Smarty 模板 中 的 ldelim 和 rdelim 标签 输出 Smarty 模板 中 的 定 界 符 ， 实 现 直接 在 Smarty 模板 页 
中 定义 JavaScript。 
上 述 技术 在 前 面 的 章节 中 已 详细 讲解 过 ， 这 里 不 再 乾 述 。 


图 设计 过 程 

(1) 在 “我 的 订单 ”功能 模块 中 ， 所 有 的 操作 都 在 usercenterorder.php 文件 中 完成 ， 包 括 当前 用 户 订单 信 
息 的 循环 输出 、 订 单 详细 信息 的 查看 、 订 单 的 取消 以 及 确认 收 货 等 ， 其 代码 如 下 : 

<2php 


seqiite once eager phps // 包 含 网 页 头 文件 
if (lisset($_SESSION["une']) | $_SESSION[unc] —") { // 判 断 当前 用 户 的 权限 
echo "<script>alert( 禁 止 非 登 录 ! '):window.location.hre 人 =".$util->baseUrl0."/index.html':</script>"; 
exit(); 
} 
iflisset($_GET['def]) && $_GET['def] —'y){ // 如 果 变 量 def 的 值 是 y， 则 执行 确认 收 货 的 操作 
SadminDB->executeSQL("update tb_order set issh=1 where ordemo=".$_GET['ordemo].™". $connID): 


} 
iflisset($_GET['def]) && $_ GET['def] 一 qx){f // 如 果 变 量 def 的 值 是 qx， 则 执行 取消 订单 的 操作 
SadminDB->executeSQL("update tb order set isqx=1 where ordermo=".$ GETT'ordemo]"". $connID): 


} 
S$isShow = F'; // 初 始 化 变量 值 为 F 
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// 如 果 变 量 orderno 的 值 不 为 空 ， 并 且 变 量 def 的 值 不 等 于 qx， 则 执行 查询 语句 ， 计 算出 订单 的 详细 信息 ， 并 且 将 查询 结果 赋 给 模板 变量 
让 (isset($_GET[ordemo]) && $_GET['ordemo']!=" && $_GET['def] (=qx){ 
Sorder = $adminDB->executeSQL("select id, ordemo. usemame, address, sex, yb, tel, idstr, numstr, rectype, paytype, goodsprice, yjprice, totalprice, 
addtime, isfk, isfh, issh from tb_order where ordermno= "trim($_GET[ordemo])."". $connID); 
Sarraylds = explode('@', Sorderfol[idstr]): 
SarrayNums = explode('@', Sorder[ol[numstr]): 
SarrayCarInfos = array(): 
S$totalPrice = 0; 
for($i= 0; Si < count(SarrayIds): $i++){ 
Sbookid = $arrayIds[$i]; 
if($bookid (= "){ 
StmpArray = array(); 
Sbookinfo = $adminDB->executeSQL("select id, bookname ,oldprice, newprice from tb_bookinfo where id=".$bookid."", $connID); 
StmpArray['id'] = $bookinfo[O]['id]; 
StmpArray[ bookname'] = $bookinfo[0][bookname']; 
StmpArray['oldprice'] = $bookinfo[O]['oldprice]; 
StmpArray['newprice'] = $bookinfo[0]['newprice']; 
StmpArray[mum'] = $arrayNums[$i]; 
S$tmpArray['smaliTotalPrice'] = Sbookinfo[0][mewprice'] * $arrayNums[$i]: 
StotalPrice += $tmpArray['smallTotalPrice] 
armray_push($arrayCarInfos, $tmpArray): 


} 


} 
$smarty->assign(arrayCarInfos'\ $arrayCarInfos); 
$smarty->assign('order’, Sorder): 
SisShow = T'; 
} 
Ssmarty->assign('isShow', $isShow); 
// 执 行 查询 操作 ， 输 出 当前 用 户 的 订单 信息 
Sorders = $adminDB->executeSQL("select ordemo, addtime, usemame, totalprice from tb_order where orderusemc=".$_SESSION["unc']." and isqx=0", 
SconnID); 


Ssmarty->assign('‘orders', $orders); // 将 查询 结果 赋 给 模板 变量 
S$smarty->display('‘usercenterorder.phtml); // 指 定 模 板 页 
require_once ‘footer.php'; // 包 含 网 站 的 尾 文件 


(2) 在 views 文件 夹 下 创建 usercenterorder.phtml 模板 文件 ， 根 据 模板 变量 中 传递 的 数据 完成 “我 的 订单 ” 
模块 页 面 的 设计 。 首 先 ， 通 过 section 语句 循环 输出 当前 用 户 的 订单 信息 并 创建 “查看 ” 超 链 接 链 接 到 本 页 ， 将 
订单 号 作为 参数 进行 传递 。 然 后 ， 应 用 站 语句 判断 当 模 板 变量 $isShow 的 值 为 工时， 输出 模板 变量 中 传递 的 订 
单 详细 信息 。 最 后 ， 创 建 “ 取 消 订购 ”和 “确认 收 货 ”按钮 ， 通 过 onclick 事件 调用 JavaScript 完成 对 订单 的 处 
理 操 作 ， 其 关键 代码 如 下 : 


{section name=oID loop=$orders} 
<div style="width:90%; height:20px; border-bottom:1px solid #0C92AB; border-left:1px solid #0C92AB; border-right:1px solid #0C92AB; 
padding-top:3px"> 
<li style="display:inline; width:26%: float:left; border-right:1px solid #0C92AB">{$orders[oID].orderno} </li> 
<li style="display:inline: width:2296: float:left; border-right: lpx solid #0C92AB">{$orders[oID].usemame} </li> 
<li style="display:inline; width:22%; float:left; border-right: px solid #0C92AB"> {util->moneyFormat p=$orders[oID].totalprice} </li> 
<li style="display:inline; width:2296: float:left: border-right: px solid #0C92AB">{$orders[oID].addtime}</li> 
li style="display:inline: width:896: float:left"><a href=" {util->baseUrl}/usercenterorder-{$orders[oID].ordemo} html class="al"> 查 看 </a></li> 
</div> 
{/section} 
{if $isShow — T'} 
<div style="width:680px: border-top:1px dotted #CCCCCC: border-bottom: px dotted #CCCCCC: padding:15px"> 
<div style="width:630px: height:22px: text-align:left padding-top:Spx"> 
<li style="display:inline: width:200px: height:22px: background-color:#006D84: padding-top:5px: padding-left:10px:; color:-#FFFFFF: 
float:left"> <strong> 订 单 号 : {$order[0].ordemo}</strong></li> 
<li style="display:inline: width:200px; height:22px: padding-top:5px; float:right"> 订 购 时 间 : {Sorder[0].addtime}</li> 
</div> 
<!-- 省 略 了 部 分 代码 -> 
<div style="width:680px: height:30px: padding-top:3px; text-align:left"><strong> 订购 状态 </strong>&nbsp:&nbsp:&nbsp:[&nbsp: 已 收 款 : 
<input type="checkbox" disabled {if $order[0].isfk 一 1 }checked{/if} 广 &nbsp:&nbsp: 已 发 货 : 
<input type="checkbox" disabled {if $order[0].isth 一 1 }checked{/i@/> 已 收 货 : 
<input type="checkbox" disabled {if $order[O] issh 一 1 }checked{/if} />&nbsp:] 
<input type="button" value=" 取 消 订购 " {if Sorder[0]issh 一 1 || Sorder[0] is 全 一 1 || Sorderfo] isfh 一 1 }disabled{/if} 
onclick="javascript:if(window.confirm(' 您 确认 取消 该 订单 吗 ? )==true) {ldelim}windowlocation href='usercenterorder-{$order[0].ordermo} 
-qxhtml';{rdelim}"/> 
<input type="button" value=" 确 认 收 货 " onclick="javascript:if(window.confirm(' 您 确认 已 经 收 货 了 吗 ? ) 一 tue)fldelim} 
‘window.location href='usercenterorder- {Sorder[0].ordermo}-y.html'; {rdelim}" fifSorderfo]issh 一 1 }disabled{/if}/> 
</div> 
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<div> 
MW 


心 法 领悟 597: 实现 退出 登录 功能 。 

用 户 在 登录 成 功 后 ， 可 以 修改 注册 信息 、 登 录 密码 ， 查 看 订单 信息 和 提交 意见 反馈 等 ， 那 么 如 何 实现 退出 
登录 呢 ? 

实现 退出 登录 功能 应 用 的 是 session start()、session_unregister() .unset0 和 header() 函 数 。 首 先 初 始 化 SESSION 
变量 , 然后 注销 SESSION 变量 unc, 接着 删除 SESSION 变量 ,最 后 跳 转 到 index.html 页 面 , 该 功能 存储 于 logout php 
文件 中 。 


力 实例 说 明 


在 明日 科技 图 书 网 的 用 户 登 录 页 面 中 ， 有 一 个 “ 找 回 密码 ” 
超 链 接 ， 单 击 该 链接 将 执行 密码 找 回 的 操作 。 第 一 步 : 输入 用 
户 的 昵称 ;第 二 步 : 输入 密码 提示 答案 ; 第 三 步 : 如 果 输 入 答 
案 不 正确 ， 则 给 出 错误 提示 信息 ， 否 则 弹出 密码 找 回 成 功 对 话 
框 并 且 显 示 原 密码 ， 也 可 以 选择 重新 设置 密码 ， 其 运行 效果 如 


图 15.25 所 示 。 me 
图 关键 技术 二 一 


在 找 回 密码 功能 实现 过 程 中 ， 应 用 到 的 技术 如 下 ; 9 入 加 闪 各 的 报信 活 各 
(1) 应 用 Smarty 模板 中 的 ldelim 和 rdelim 标签 输出 Smarty 模板 中 的 定 界 符 ， 实 现 直接 在 Smarty 模板 页 
中 定义 JavaScript。 
(2) 应 用 window 对 象 中 的 open() 方 法 打开 openfindpwd.php 文件 ， 开 始 执行 找 回 密码 的 操作 。 
(3) 应 用 PHP 中 提供 的 MySQL 数据 库 函 数 操作 MySQL 数据 库 ， 完 成 找 回 密码 、 更 改 密码 的 操作 。 其 中 ， 
首先 在 conn.php 文件 中 应 用 mysql_connectO、mysql select db0 和 mysql_query0 函 数 完 成 与 数据 库 服务 器 、 数 据 
库 的 连接 ， 并 且 设 置 编码 格式 ， 其 代码 如 下 : 


<?php 

$conn=mysql_connect("localhost", "root”,"111"); // 连 接 数 据 库 服务 器 
mysql_select_db("db_database15",$conn): /连接 数据 库 
mysql_query("set names gb2312"): /设置 数据 库 编码 格式 
?> 


图 设计 过 程 
(1) 在 模板 页 login.phtml 中 应 用 Smarty 模板 中 的 ldelim 和 rdelim 标签 直接 编写 JavaScript 脚本 方法 


openfindpwd0， 打 开 openfindpwd.php 文件 ， 其 关键 代码 如 下 : 
<script language="JavaScript" type="text/iavascript"> 
function op 
{ldelim} 
window.open("openfindpwd.php"."newframe"."lefi=200.top=200,width=200.height=100.menubar=no.toolbar=no.location=no.scrollbars=no,location=no 
");{rdelim} 
‘</script> 
<a href="javascript:openfindpwd0O" class="al">[ 找 会 密码 ]</a> 


(2) 新 建 openfindpwd.php 文件 ， 创 建 form 表单 ， 提 交 要 找 回 密码 的 用 户 的 昵称 ， 并 且 通 过 JavaScript 脚 
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本 判断 用 户 提交 的 数据 是 否 为 空 ， 将 数据 提交 到 findpwd.php 页 面 。 

(3) 新 建 findpwd.php 文件 。 首 先 包 含 数据 库 连接 文件 conn.php， 然 后 判断 用 户 提交 的 昵称 在 数据 库 中 是 
否 存在 ， 如 果 存 在 则 输出 此 用 户 注册 时 填写 的 密码 提示 问题 ， 并 且 通 过 form 表单 将 问题 的 答案 提交 到 
showpwd.php 文件 中 进行 处 理 。 

(4) 新 建 showpwd.php 文件 ,首先 包含 数据 库 的 连接 文件 conn.php， 然后 判断 用 户 提交 的 问题 答案 是 否 正 
确 ， 如 果 不 正确 则 给 出 提示 信息 并 跳 转 到 上 一 页 ， 如 果 正 确 则 输出 显示 原 密码 和 重 设 密码 的 超 链接 。 

(5) 新 建 changepwd.php 文件 , 创建 重新 设置 密码 的 form 表单 , 将 重新 设置 的 密码 提交 到 savechangepwd. 
php 文件 中 。 

(6) 新 建 savechangepwd.php 文件 ， 完 成 用 户 密码 的 更 新 ， 其 代码 如 下 : 


<?php 

include_once ("conn php"); // 连 接 数据 库 
Struepwd =$_POST[userpwd1]: /获取 提交 的 新 密码 
Spwd = md5($truepwd); // 对 密码 进行 md5 加 密 


if (mysql_query("update tb_user set pwd='$pwd',truepwd='$truepwd' where id=" . $_POST["userid"] . "", $conn)) { // 执 行 更 新 操作 
echo "<script>alert(' 密 码 更 改 成 功 !");history.back(;</script>"; 

yelse{ 

echo "<script>alert( 密 码 更 改 失败 !):history.back0;</script>"; 


} 
mysql_close($conn): /关闭 数据 库 连接 
> 
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心 法 领悟 598: MySQL 数据 库 函数 。 

在 明日 科技 图 书 网 站 项 目 中 , 为 了 体现 本 章 内 容 的 综合 性 ， 不 但 应 用 Smarty 模板 和 ADODB 类 库 技术 ， 同 
时 也 融入 了 MySQL 函数 操作 MySQL 数据 库 的 方法 。 有 关 通 过 MySQL 函数 操作 MySQL 数据 库 的 详细 讲解 可 
以 参考 第 8 章 的 内 容 。 


15.4 数据 的 输出 


本 节 将 介绍 数据 输出 功能 的 实现 ， 包 括 图 书 导航 、 图 书 分 类 、 特 别 图 书 、 图 书 试 读 、 图 书 详细 信息 和 新 闻 
公告 等 功能 。 
高 级 
实 斧 
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| | 实例 说 明 当前 邱 肌 : 全 六 图 书 各 所 
明日 科技 图 书 网 站 中 ， 通 过 图 书 导航 功能 展示 出 网 站 中 图 书 的 所 有 类 别 ， 并 且 : i 
将 图 书 划 分 为 初级 、 中 级 和 高 级 3 种 类 型 ,图书 导航 功能 的 运行 效果 如 图 15.26 所 示 。 
力 关键 技术 
图 15.26 图 书 导航 功能 
实现 图 书 导 航 功 能 应 用 的 关键 技术 如 下 : 


(1) 在 index.php 动态 页 中 ， 应 用 数据 库 管理 类 中 的 executeSQL0 方 法 查询 出 图 书 大 类 和 小 类 数据 表 中 的 
数据 。 其 中 关于 数据 库 的 连接 和 操作 方法 可 以 参考 本 章 实例 586 和 实例 587。 

(2) 在 index.phtml 模板 页 中 ， 应 用 Smarty 模板 中 的 站 语句 根据 模板 变量 传递 的 值 判 断 应 具体 输出 哪 种 类 
型 的 数据 ， 然 后 应 用 section 语句 进行 嵌 套 ， 完 成 图 书 大 类 与 小 类 的 对 应 循环 输出 。 
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有 关 Smarty 模板 中 让 语句 和 section 语句 的 详细 讲解 可 以 参考 第 14 章 的 内 容 。 
图 设计 过 程 


(1) 在 index.php 动态 页 中 ， 首 先 判断 变量 Seetype 的 值 ， 如 果 为 空 ， 则 赋值 为 1， 否 则 直接 将 变量 的 值 赋 
给 模板 变量 。 然 后 ， 应 用 数据 库 管理 类 中 的 executeSQL( 方 法 查询 tb_bigtype 和 tb_smalltype 表 中 存储 的 图 书 类 


别 数 据 ， 同 样 将 查询 结果 赋 给 模板 变量 ， 其 关键 代码 如 下 : 
这 lisset($_GET[cctype]) ||$_GET['cctype =—="){ /判断 变量 值 是 否 为 空 
= // 为 变量 赋值 
jelse{ 
$cctype = $_GET['cctype']: 


S$smarty->assign('cctype', $cctype); // 将 变量 值 赋 给 模板 变量 

// 查 询 图 书 大 类 中 的 数据 

Sbigtypes = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime", $connID); 
Ssmarty->assign('bigtypes'. $bigtypes); 

// 查 询 图 书 小 类 中 的 数据 

$smalltypes = $adminDB->executeSQL("sclect id, typename, bigtypeid from tb_smalltype order by addtime", $connID); 
Ssmarty->assign('smalltypes'. $smalltypes); 


(2) 在 index.phtml 模板 页 中 ， 根 据 模板 变量 的 值 判断 输出 全 部 图 书 导航 、 初 级 入 门类 图 书 、 提 供 必 备 类 
图 书 还 是 高 级 导向 类 图 书 ， 然 后 通过 section 语句 翌 套 循环 输出 所 有 图 书 类 别 ， 其 关键 代码 如 下 : 


{section name=bID loop=$bigtypes} 
<div style="width: ne > 
i idth: 100%; height:25px: text-align:left; padding-left:6px; padding-top:Spx: color:#990000"> 
re “&nbsp; {util->unHtml p=$bigtypes[bID].typename} 
iv 
<div style="width:100%"> 
{section name=sID loop=$smalltypes} 
i Sse el i $smalltypes[sID].bigtypeid} 
<div style="wid height: 18px: float:left: text-align:left padding-left:12) 
-&enl oo {Ssmalltypes[sID] id}- seo 1j1{clseif Scctype 一 2}2{clseif gcctype 一 3}3 {clseif 
S$cctype—4}4{/if}.html" class="a4"> futil->unHtml p=$smalltypes[sID] typename}</a> 
div> 


{/section} 
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心 法 领悟 599: section 语句 的 嵌 套 循环 。 

section 语句 的 嵌 套 循环 需要 让 语句 的 辅助 才能 够 完成 。 首 先 执行 section 语句 的 外 层 循环 ， 并 输出 指定 的 数 
据 ， 然 后 执行 section 语句 的 内 层 循环 ， 在 内 层 循 环 中 应 用 站 语句 进行 判断 ， 当 外 层 循环 中 的 指定 值 与 内 层 循环 
中 的 指定 值 相 同时 ， 才 输出 内 层 循环 中 的 指定 数据 。 

在 本 实例 中 ， 首 先 循环 输出 模板 变量 Sbigtypes 中 的 类 型 名 称 ， 然 后 执行 内 层 循环 输出 模板 变量 gsmalltypes 
中 的 数据 ， 此 时 应 用 让 语句 进行 判断 ， 只 有 当 $bigtypes 中 的 id 与 $smalltypes 中 的 bigtypeid 值 相同 时 ， 才 输出 
$smalltypes 中 的 类 型 名 称 ， 并 且 为 这 个 类 型 名 称 创建 超 链接 。 


“ “ We.... ss | 
力 实例 说 明 


明日 科技 图 书 网 是 一 个 专业 的 I 类 图 书展 示 和 销售 平台 ， 为 了 方便 读者 选 购 ， 特 将 图 书信 息 按 类 别 展 现 出 
来 。 用 户 在 选 购 图 书 时， 首先 选择 图 书 大 类 ， 然 后 在 大 类 中 选择 图 书 的 小 类 ， 这 样 就 可 以 将 该 类 别 的 所 有 图 书 
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以 分 页 的 形式 展现 出 来 。 明 日 科技 图 书 网 图 书 分 类 展示 效果 如 图 15.27 所 示 。 


3 上 尝 时 间 1 出 新 问 上 优 术 全 丙 | 让 六 类 由 到 少 
图 书 小 类 

“| 全 部 | ?XI | 要 丙 少 各 | 再 姑 导 各 小 
二/ 共 1 页 。 兰 页 上 -页 下 -页 尼 页 


图 15.27 明日 科技 图 书 网 图 书 分 类 展示 效果 


力 关键 技术 


实现 图 书 分 类 展示 的 关键 是 数据 表 的 创建 , 在 图 书 大 类 表 tb_bigtype 和 图 书 小 类 表 tb_smalltype 之 间 存 在 一 
个 关联 的 字段 ， 通 过 该 字段 确立 两 个 表 中 数据 的 从 属 关系 。 这 里 将 tb_bigtype 表 中 的 id 字段 与 tb_smalltype 表 
中 的 bigtypeid 字段 建立 关联 ， 即 在 tb_smalltype 表 中 ， 根 据 字 段 bigtypeid 的 值 可 以 确定 该 小 类 属于 哪个 大 类 。 
图 设计 过 程 

在 图 书 分 类 展示 页 面 中 ， 浏 览 者 可 以 从 最 上 面 的 图 书 大 类 中 选择 要 购买 图 书 的 大 类 ， 然 后 在 子 类 中 选择 具 
体 的 语言 类 别 ， 这 样 就 可 以 将 指定 语言 类 别 的 图 书展 示 出 来 ， 同 时 可 以 按照 指定 的 排列 方式 和 图 书 层次 对 图 书 
的 显示 顺序 进行 调整 。 具 体 实现 过 程 如 下 : 

(1) 在 listbook.php 文件 中 ， 首 先 使 用 $_GET 全 局 数组 接收 传递 到 页 面 的 排序 方式 标识 、 图 书 层次 标识 和 


当前 页 显示 的 页 码 ， 然 后 使 用 分 页 类 的 pageData0 方 法 获取 分 页 参数 ， 最 后 指定 模板 页 ， 其 关键 代码 如 下 : 
if(! isset($. Type 了 ||$_GET[pltype] —") { /[ 获 得 图 书 排列 方式 
Vast 
Spltype = $_GET['pltype']: 


S$smarty->assign('pltype', $pltype); 

if(! isset($_GET['cctype']) || $_GET['cctype] —") { // 获 得 图 书 层次 标识 
Sectype ='1'; 

yelse{ 
S$cctype = $_GET['cctype']: 

} 

S$smarty->assign('cctype', $cctype): 

if (lisset($_GET['page']) || $_GET['page] —") { // 获 得 当前 要 显示 的 页 码 
Spage ='1'; 

}else{ 
Spage =$ GET['page'l: 


S$smarty->assign('page', Spage): 
$smalltype = $adminDB->executeSQL("select id, bigtypeid. typename from tb_smalltype where id='$stid™", $connID): // 查 询 图 书 小 类 
Ssmarty->assign('smalltype', $smalltype); 
Sbigtype = $adminDB->executeSQL("select id. typename from tb_bigtype where id=" . Ssmalltype[0][bigtypeid] . "". $connID); 
S$smarty->assign(bigtype' $bigtype); 
$smalltypes = $adminDB->executeSQL("select id, typename from tb_smalltype where bigtypeid=" . Sbigtype[o]['id] . "", $connID); /查询 图 书 大 类 
Ssmarty->assign('smalltypes', $smalltypes); 
证 人 1){ // 设 置 图 书 层次 条 件 
=" and smalltypeid =" . $stid . ™"; 

} es 20{ 

Swhere =" and bookce = 1 and smalltypeid =" . $stid . "": 
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} elseif ($cctype — 30 { 
Swhere =" and bookcc=2 and smalltypeid =". $stid . ™"; 
} elseif ($cctype — '4) { 
Swhere =" and bookcc=3 and smalltypeid =" . $stid . ™"; 
} 


if($pltype —'1) { // 设 置 图 书 排列 方式 
Sorder = "addtime dese"; 
} 和 pe | 
= "pubtime dese"; 
} sae (pipe —3) { 
Sorder = "newprice ase"; 
} elseif (Spltype — 4) { 
Sorder = "browsertime dese"; 


} 
$sql = "select tb_bookinfo.id, tb_bookinfo.bookimg, tb_bookinfo.oldprice. tb_bookinfo.newprice, tb_bookinfo.about, tb_bookinfo.browsertime, 
tb1 bookinfo.bookname, tb_bookinfo.writer, tb_bookinfo.pubtime, tb | bookinfo.addtime, tb bookinfo .ishave, tb_pub.pubname from tb_bookinfo, tb_pub 
where tb_bookinfo.pubid = tb_pub.id " . $where . " order by " . $order . " // 构 建 查询 语句 
$bookinfos = $pageDB->pageData($sql, $connID, 10. $page); /执行 分 页 查询 
Samarty->assign(bookinfos' $bookinfos); 
(2) 在 views\listbook.phtml 模板 页 中 ， 应 用 section 语句 完成 指定 类 别 图 书信 息 的 分 页 显示 ， 关 键 代码 如 下 : 
{if $bookinfos.countRs > 0} 
I 
<div style="width:930px"> 
<br> 
<div style="width:100%%:; height:180px"> 
<div style="width:20%; height:100%; float:left"> 
<a href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} .html"><img sre="{$system[01.bookimgurl}/ 
{$bookinfos.data[pbID].bookimg}" width="110" height="150" style="border:1px solid #123456" /></a> 
</div> 
<div style="width:7896: height:100%; float:right; text-align:left: font-size:13px"> 
<li style="display:inline"><a href=" {util->baseUr}/bookinfo- {$bookinfos.data[pbID].id} html" class="a5"><strong> 
{$bookinfos.data[pbID].bookname} </strong></a></li> 


<br><br> 

<li style="display:inline"> 出 版 社 ，{$bookinfos.data[pbID].pubname} </li> 
<br><br> 

<li style="display:inline"> 作 者 : {$bookinfos.data[pbID].writer}</li> 
<br><br> 


<li style="display:inline"> 上 架 时 间 : {$bookinfos.data[pbID].addtimeltruncate:10:"}&nbsp;&nbsp; 出 版 时 间 : 
{$bookinfos.data[pbID].pubtimeltruncate:10:"} &nbsp;&nbsp; 浏 览 次 数 ， {$bookinfos.data[pbID].browsertime} &nbsp; 次 </li> 
<br><br> 
<li style="display:inline"> 市 场 价 :<img sre=" {util->baseUrl}/img/mark_green.gif" />&nbsp:<s>{util->moneyFormat 
p=$bookinfos.data[pbID].oldprice} </s>&nbsp;&enbsp;<font color="#FF0000"> 会 员 价 : <img sre=" {util->baseUrl}/img/mark_red.gif 
/>&enbsp; {util->moneyFormat p=$bookinfos.data[pbID].newprice} </font> 
</li> 
<br><br> 
li style="display:inline"><a href=" {util->baseUrl} /cart- {$bookinfos.data[pbID].id}-add.html"><img sre=" {util->baseUrl}/ 
imgybutton_order.gif' border="0"/></a>é&nbsp:<a href=" {util->baseUrl} /bookinfo-{$bookinfos.data[pbID].id} html"><img sre=" {util->baseUrl} /img/ 
button_info gif' border="0"/></a></li> 
</div> 
</div> 
<div style="width:95%; height:50px: border:1px solid #CCCCCC: text-align:left; line-height:18px: color:#990000; padding: Spx"> 
{util->unHtml p=$bookinfos.data[pbID].aboutltruncate:420:"...":false} 
</div> 
</div> 
{/section} 
{else} 
<div style="width:500px; height:80px; font-size:14px; color:#FF0000"> 
<img sre=" {util->baseUrl}/img/mark_telllogin.gif"><br /> 
<strong> 对 不 起 ， 暂 无 该 类 图 书 ! </strong> 


</div> 
他 


国 秘笈 心 法 


心 法 领悟 600: 为 什么 编辑 的 模板 页 文件 后 缀 是 .phtml， 而 输出 时 文件 的 后 缀 是 .html。 
因为 本 实例 的 开发 应 用 PHP 伪 静 态 技术 ,会 对 输出 文件 的 后 级 和 传递 的 参数 进行 重新 定义 。 伪 静态 技术 的 


执行 要 通过 .htaccess 文件 。 


852 
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| 
高 级 : 
趣味 指教: od 


力 实例 说 明 


为 了 满足 不 同 用 户 的 需要 ， 在 制作 明日 科技 图 书 网 时 ， 设 置 了 特别 图 书展 示 模块 ， 该 模块 可 以 对 新 书 、 特 
价 图 书 、 热 卖 图 书 和 期 书 进行 分 页 展示 ， 其 运行 效果 如 图 15.28 所 示 。 


长 雪 币 明日 科 孔 书后 


Www-mrpooks-cn 


| 多 报 作 | 要件 与 续 护 ， 黄 化 


您 当前 的 位 置 : 明日 网上 书店 >》 热卖 图 节 
扫 问 本 5 本 吉星 示 切 本 第 1 页 / 共 ! 页。 首页 上 -页 下 -页 尼 页 。 [一 一 
ATizaal Ce 项 目 开发 卖国 自学 后 和 (1CD)》 | 特别 图 书 | 


出 版 社 ， 人 民 都 电 出 版 社 
用 目 开 友 2 
法 例 6 和 作者 : 明日 科 校 王 小 科 票 冰 如 双 
= 上 染 叶 岂 : 2009-07-0 。。 出 所 时 间 ; 2008-Ce-00 。。 和 次 委 559 次 
市 场 价 ， 西 45r-88 会 员 价 : 西 45.00 
一 Ns pan 


企业 这 入 人 了 和 素 久 和 实际 项 目 开发 和 丰 守 ， 从 其 人 或 度 册 共 和 烦人 开发 人 条 外 ， 全 末了 和 开演 本 

忆 训 人 光 及 行业 三江 ， 实 下 性 治 。 通 这 学 习 ,多 寺 呆 以 了 解 千 个 和 业 信 特点 能 中 针对 蘑 一 站 半生 软 社 开发， 也 可 以 通 讨 北 朱 中 提供 生计 例 尖 代码 可 数 加 床 波 行 二 

识 开 复 ， 忆 节省 开 家 下 冰 加 过 要 隐 卫 网 - 
机 用 卫 于 雍 雪 。 北 关 提 供 了 书 中 所 有 案 和 的 当代 码 。 这 些 刘 代办 各 经 过 本 < 外， 在 tinlms 


机 志 阳 忆 闪 6 玉生 页 史 玉 10 本 第 1 页 / 革 1 页 。 首页 上 -页 下 -页 加 页 


15.28 ”特别 图 书 分 页 展示 


图 关键 技术 


在 特别 图 书 模块 中 ， 包 括 新 书 推荐 、 特 价 图 书 、 热 卖 图 书 、 期 书 和 试 读 5 个 子 选项 ， 在 这 5 个 子 模块 之 间 
的 跳 转 根据 的 是 超 链接 参数 t 传递 的 变量 值 ， 在 动态 文件 listsepbook.php 中 应 用 站 语句 进行 判断 ， 并 且 根 据 判 
断 的 结果 为 模板 变量 赋值 ， 然 后 在 模板 变量 中 输出 对 应 的 内 容 。listsepbook.php 文件 的 关键 代码 如 下 : 
if($_GET[t] — new) { 
Snowtype = ' 新 书 推荐 


Sandwhere = "isnew = 1"; 
} elseif ($_GET[Y] 一 "sepprice) { 
特价 图 书 : 


nowtype 一直 中 
Sandwhere = "ishotsell= 1"; 


S$_GET[t]): 
->assign(nowtype' $nowtype): 
在 完成 特别 图 书 的 分 贡 输 出 时， 编写 一 个 多 表 查 询 的 SQL 语句 ， 对 tb_bookinfo 和 tb_pub 两 个 数据 表 进 行 


查询 ， 其 使 用 的 SQL 语句 如 下 : 
$sql = "select tb bookinfo id. tb bookinfo bookimg. tb bookinfo about tb bookinfo browsertime. tb bookinfo.oldprice, tb bookinfo.newprice, 
tb_bookinfo.bookname, tb_bookinfo writer tb_bookinfo pubtime. tb_bookinfo.addtime, tb_bookinfo ishave, tb_pub pubname from tb_bookinfo, tb_pub 


where tb_bookinfo.pubid = tb_pub.id and " . $andwhere . " order by tb_bookinfo.addtime desc": 


PHP 开发 实例 大 全 (基础 卷 ) 


图 设计 过 程 
(1) 建立 listsepbook.php 文件 用 来 实现 业务 逻辑 。 在 该 文件 中 ， 首 先 使 用 $_GET 全 局 数组 接收 查询 字符 串 
参数 t 的 值 ， 然 后 根据 该 值 决 定 当前 页 面 要 显示 的 内 容 并 构建 查询 语句 ， 最 后 使 用 分 页 类 的 pageData() 方 法 实现 


分 页 查询 ， 其 完整 代码 请 参考 本 书 光盘 ， 这 里 不 再 歼 述 。 
(2) 建立 模板 页 listsepbook.phtml， 通 过 section 语句 分 页 输出 指定 类 别 下 的 图 书信 息 ， 其 关键 代码 如 下 : 


{if$bookinfos.countRs > 0} 
{section name=pbID loop=$bookinfos.data} 
<div style="width:930ps"> 
<br> 
<div style="width:100%; height:180px"> 
<div style="width:20%; height:10096: float:left"> 
<a href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} html"><img sre="{$system[0].bookimgurl}/ 
{$bookinfos.data[pbID].bookimg}" width="110" height="150" style="border:1px solid #123456" /></a> 
</div> 
<div style="width:78%%; height:10096: float:right; text-align:left; font-size:13px"> 
<li style="display:inline"><a href="{util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} .html" class="a5"><strong> 
{$bookinfos.data[pbID].bookname} </strong></a></li> 


<br><br> 

<li style="display:inline"> 出 版 社 ，{$bookinfos.data[pbID].pubname}</li> 
<br><br> 

<li style="display:inline"> 作 者 : {$bookinfos.data[pbID].writer}</li> 
<br><br> 


<li style="display:inline"> 上 架 时 间 : {$bookinfos.data[pbID].addtimeltruncate:10:""}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 出 版 时 
间 : {$bookinfos.data[pbID].pubtimeltruncate:10:"}&nbsp;é&nbsp;&nbsp;&nbsp;&nbsp;&nbsp: 浏 览 次 数 : {$bookinfos.data[pbID].browsertime}&nbsp; 
次 </li> 
<br><br> 
<li style="display:inline"> 市 场 价 ，<img sre=" {util->baseUrl}/img/mark_green.gif' />&nbsp:<s>futil->moncyFormat 
p=S$bookinfos.data[pbID].oldprice}</s>&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbspi&nbspi&nbspi&nbsp: 
<font color="#FF0000"> 会 员 价 :<img sre="{util->baseUd}/img/mark_red.gif" />&nbsp; {util->moneyFormat 
p=$bookinfos.data[pbID].newprice} </font> 
</li> 
<br><br> 
<li style="display:inline"><a href=" {util->baseUrl} /cart-{$bookinfos.data[pbID].id}-add.html"><img 
sre=" {util->baseUrl} /img/button_order.gif” border="0"/></a>&nbsp:&nbsp:&nbsp:&nbsp:<a 
href=" {util->baseUrl}/bookinfo- {$bookinfos.data[pbID].id} html"><img sre=" {util->baseUrl}/img/button_info.gif" border="0"/></a></li> 
</div> 
</div> 
<div style="width:95%; height:SOpx: border: 1px solid #CCCCCC; text-align:left: line-height18px: color:#990000; padding:Spx"> 
{util->unHtml p=$bookinfos.data[pbID].aboutltruncate:420:"...":false} 
</div> 
</div> 
{/section} 
{else} 
<div style="width:500px; height:80px; font-size:14px: color:#FF0000"> 
<img sre=" {util->baseUrl}/img/mark_telllogin.gif’><br /> 
<strong> 对 不 起 ， 暂 无 新 书信 息 ! </strong> 
</div> 
UD 


力 秘笈 心 法 


心 法 领悟 601: SQL 语句 中 的 多 表 查 询 。 

在 SQL 语言 中 ， 通 过 where 子 句 实现 多 表 查 询 ， 所 要 查找 的 字段 名 用 “表明 .字段 名 ”表示 ， 这 样 可 以 避免 
因 表 之 间 字 段 重 名 而 无 法 获知 该 字段 属于 哪个 表 。 在 where 子 句 中 多 个 表 之 间 所 形成 的 联动 关系 应 按 如 下 格式 
区 1 字段 - 表 字段 and 其 他 查询 条 件 

多 表 查 询 的 语法 如 下 : 

sleet 字段 名 fom 表 1 表 2.。where 表 工 字段 - 表 2 字段 and 其 他 查询 条 件 
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趣味 指数 ， 请 请 坪 家 | 


力 实例 说 明 
为 了 能 够 让 读者 了 解 某 本 图 书 的 大 概 内 容 ， 吸 引 更 多 读者 购买 图 书 ， 在 制作 明日 科技 图 书 网 时 ， 将 图 书 斌 


读 作为 单独 模块 ， 其 运行 效果 如 
长 可 而 明日 和 扩 书 店 


Wwwrmrpooks-em 


图 15.29 所 示 。 


其 书 


黄页 要 书 将 从 。 热卖 


冤 当 前 的 位 置 ， 明 电网 上书 居 27 国 书 区 该 下 过 
于吉 共事 全 而 10 可 第 1 页 /其 1 页 。 首页 上 一 页 下 一 页 尾 责 


Ch 开发 二 验 技 巧 宝 并》 


二 有 人 组 了 1009 人 关于 Wisaal Ph 开发 的 和 台大 了 提亲 开发 中 的 各 和 袜 际 大 求 。 全 世 分 广 2 全， 分 虽 杂 河 训 基础 匡 大 型 ， 开 发 环 次 ，NB 尖 几 技 本 ， 玉 人 
tte rte the git au tre holon oh Hy 
Tleroet 网 机、ATL Cen 村、 所 本 六 RUB: 宁 引 


ET 本 本 0 本 第 ! 页 / 失 /页 。 商 页 上 -本 下 一 页 四 再 


图 15.29 ” 试 读 图 书展 示 


图 关键 技术 


实现 图 书 试 读 的 关键 技术 是 如 何 获取 到 试 读 文 件 ， 本 实例 中 应 用 HTTP 方式 完成 试 读 文件 的 下 载 操作 ， 其 
中 关键 是 header0 函 数 的 应 用 。 有 关 应 用 HTTP 方式 进行 下 载 的 详细 讲解 请 参考 本 书 第 4 章 的 内 容 。 
在 本 项 目 中 ， 下 载 的 操作 在 upfiles\doc\download.php 文件 中 完成 ， 同 时 还 对 文件 被 下 载 的 次 数 进行 统计 ， 


其 关键 代码 如 下 
?php 
require_once "lzh.inc.php'; /包含 类 的 实例 化 文件 
$filename=$_GET['filename']; // 获 取 文件 名 称 
S$rid = $_GET['rid]; // 获 取 文 件 的 计 
S$system = $adminDB->executeSQL("update tb_read set downtimes = downtimes+l where id='$rid", $connID); /执行 更 新 操作 
这 file_exists($filename) 一 false){ 1/ 判断 上 传 文件 是 否 存 在 
echo "<script>alert( 对 不 起 ， 本 站 暂时 停止 该 文件 下 载 1):history.back0:</script>"; 
exit; 
} 
$fp=fopen($filename,"r"); 1/ 打 开 上 传 文件 
header("Content-type:application/octet-stream"); 
header("Accept-ranges:bytes"): 


header("Accept-length:".filesize($filename)): 


header("Content-Disposition:attachment:filename=".$filename):; 
echo fread($fp,filesize($filename)); // 读 取 上 传 文件 内 容 
flose($fp); 1/ 关闭 文 件 

力 设计 过 程 


图 书 试 读 模块 对 明日 科技 图 书 网 站 中 所 有 可 以 试 读 的 图 书 进行 分 页 展示 。 

(1) 新 建 listreadbook.php 文件 ， 完 成 所 有 试 读 图 书 的 分 页 查询 操作 。 首 先 通过 $_GET 全 局 数组 接收 查询 
字符 串 page 的 值 ， 该 值 用 来 指定 当前 页 面 要 显示 的 内 容 。 然 后 构建 查询 语句 ， 通 过 分 页 类 的 pageData() 方 法 获 
得 分 页 数据 。 最 后 将 查询 结果 赋 给 模板 变量 并 且 指 定 模板 页 ， 具 体 实现 代码 如 下 : 


PHP 开发 实例 大 全 〈 基 础 卷 ) 


Tequire_once header.php'; 

Snowtype= ' 图 书 试 读 下 载 '; 

S$smarty->assign('nowtype', $nowtype); 

S$system = $adminDB->executeSQL("select bookimgurl readur] from tb_system where mark = 1", $connID); 


S$smarty->assign('system', $system); // 查 询 系统 配置 信息 

if(! isset($_GET['page']) || $_GET['page] —") { /获取 当前 页 码 
Spage ="1'; 

}else{ 


Spage =$ GETI'page'l; 


} 

$sql = "select tb_bookinfo.id, tb_bookinfo.bookimg, tb_bookinfo.oldprice, tb_bookinfo.newprice, tb_bookinfo.about, tb_bookinfo.browsertime, 
tb_bookinfo.bookname, tb_bookinfo.writer, tb_bookinfo.pubtime, tb_bookinfo.addtime, tb_bookinfo.ishave, tb_pub.pubname, tb_read.id as readid, 
tb_read filename from tb_bookinfo, tb_pub, tb_read where tb_bookinfo.pubid =tb_pub.id and tb_read.bookinfoid =tb_ bookinfoid order by 


tb_read.addtime dese"; // 构 建 查询 语句 
S$bookinfos = $pageDB->pageData($sql, $connID, 10. Spage); // 执 行 分 页 查询 
Ssmarty->assign(bookinfos' $bookinfos); 

S$smarty->display('listreadbook.phtml’); 


Tequire_once ‘footer.php'; 


(2) 新 建 模板 文件 listreadbook.phtml， 应 用 section 语句 完成 试 读 图 书 的 分 页 输出 ,创建 “ 试 读 下 载 ” 超 链 
接 ， 链 接 到 upfiles\doc\download.php 文件 ， 完 成 试 读 文 件 的 下 载 操作 ， 其 关键 代码 如 下 : 


{if $bookinfos.countRs > 0} 
{section name=pbID loop=$bookinfos.data} 
<div style="width:930px"> 

<br> 


<div style="width:100%; height:180px"> 
<div style="width:20%; height:100%; float:left"> 
<a href=" {util->baseUrl}/bookinfo- {$bookinfos.datafpbID].id} .html"><img src=" {$system[01.bookimgurl}/ 
{$bookinfos.data[pbID].bookimg}" width="110" height="150" style="border:1px solid #123456" /></a> 
</div> 
<div style="width:78%; height:100%; float:right; text-align:left: font-size:13px"> 
<li style="display:inline"><a href=" {util->baseUrl}/bookinfo-{$bookinfos.data[pbID].id} .html" class="a5"><strong> 
{$bookinfos.data[pbID].bookname}</strong></a></li> 
<li style="display:inline"><a href=" {util->baseUrl}/cart- {$bookinfos.datafpbID1id}-add.html"><img sre=" {util->baseUrl}/ 
img/button_order.gif" border="0"/></a>&nbsp:&nbsp:&nbsp:&nbsp:<a href=" {util->baseUrl}/bookinfo-{$bookinfos.data[pbID].id} html"><img 
sre=" {util->baseUrl}/img/button info.gif' border="0"/></a>&nbspi&nbsp:&nbsp:&nbsp;<a href="{$system[Ol.readurl}/download.php?rid= 
{$bookinfos.data[pbID].readid} &filename={$bookinfos.data[pbID] filename} "><img sre=" {util->baseUrl} /img/button_sdcz.gif" border="0"/></a></li> 
</div> 
</div> 
<div style="width:95%; height:SOpx: border:1px solid #C' 
{util->unHtml p=$bookinfos .data[pbID] aboutltnuncate:420: 
</div> 
</div> 
{/section} 
{else} 
<div style="width:500px: height:80px: font-size:14px; color#FF0000"> 
<img sre=" {util->baseUrl}/img/mark_telllogin.gif’><br /> 
<strong> 对 不 起 ， 暂 无 试 读 图 书信 息 ! </strong> 


Citext-align:left line-height: 18px; color:#990000; padding:5pxr> 
false} 


<div> 
UD 
(3) 有 关 下 载 试 读 文 件 的 内 容 请 参考 本 实例 的 关键 代码 ， 这 里 不 再 著述 。 


力 秘笈 心 法 
心 法 领悟 602: header0 函 数 的 常用 功能 。 


header0 函 数 的 常用 功能 有 : 
(1) 重 定向 ， 这 是 最 常用 的 功能 。 
<?php 


header("Location: http://www.mrbeed.com"): 
> 


2) 强制 客户 端 每 次 访问 页 面 时 获取 最 新 资料 ， 而 不 是 使 用 存在 于 客户 端的 缓存 。 
<9?] 
了 量 页 面 的 过 其 时 间 (用 格林 威 治 时 间 表示 ) 

header("Expires: Mon. 08 Jul 2008 08:08:08 GMT"): 


856 
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/设置 页 面 的 最 后 更 新 日 期 〔 用 格林 威 治 时 间 表示 ) ， 使 浏览 器 获取 最 新 资料 
header("Last-Modified: ". gmdate("D. dM Y H:i:s") . "GMT"); 
header("Cache-Control: no-cache, must-revalidate"); // 控 制 页 面 不 使 用 缓存 


header("Pragma: no-cache"): /参数 与 以 前 的 服务 器 兼容 ， 即 兼容 HTTP 1.0 协议 
header("Content-type: application/file"); /输出 类 型 
header("Content-Length: 。 227685"): // 文 件 长 度 


header("Accept-Ranges: bytes"); // 接 受 的 范围 单位 
// 缺 省 时 文件 保存 对 话 框 中 的 文件 名 称 
header("Content—Disposition: attachment: filename=$filename"); /实现 下 载 

?> 

(3) 输出 状态 值 到 浏览 器 ， 控 制 访问 权限 。 
< 
mn 401 Unauthorized"); 
header('status: 401 Unauthorized); 
> 

(4) 实现 HTTP 下 载 。 
header("Content-type: application/x-gzip"); 
header("Content-Disposition: attachment filename= 文 件 名 "); 
header("Content-Description: PHP3 Generated Data"); > 
HTTP 标 头 有 很 多 ， 这 里 只 介绍 下 载 的 HTTP 标 头 ， 其 代码 如 下 : 


header('Content-Disposition: attachment; filename="filename"): 


在 应 用 过 程 中 ， 唯 一 需要 改动 的 就 是 filename, 即将 filename 蔡 换 为 要 下 载 的 文件 。 


起 味 指 堵 : 请 让 朗 安 | 


力 实例 说 明 


为 了 让 浏览 者 能 够 更 加 细致 地 了 解 所 查询 图 书 的 详细 信息 ， 并 能 够 对 所 选 购 的 图 书 进行 评论 ， 还 需要 通过 
图 书 详细 信息 页 将 图 书信 息 展示 出 来 ， 效 果 如 图 15.30 所 示 。 
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图 15.30 图书 详 细 信息 展示 


图 关键 技术 


图 书 详细 信息 展示 页 中 应 用 的 技术 如 下 : 
(1) 数据 库 的 连接 、 操 作 类 。 
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(2) Smarty 模板 引擎 的 配置 类 。 
(3) 字符 串 的 处 理 类 ，baseUrl0 方 法 获取 网 址 的 相对 路 径 ，moneyFormat0 方 法 对 货币 金额 进行 格式 化 ， 


unHtml0 方 法 对 HTML 字符 串 进行 转 义 。 


(4) 应 用 Smarty 模板 中 的 truncate 方法 对 字符 串 进行 截取 。 
上 述 技术 在 前 面 的 章节 中 已 进行 过 详细 的 讲解 ， 这 里 不 再 袭 述 。 


设计 过 程 


功能 


明日 科技 图 书 网 的 图 书 详细 信息 页 面 主要 实现 对 图 书 详细 信息 的 展示 、 组 合 购买 图 书 的 推荐 和 图 书评 论 等 
， 具 体 实现 过 程 如 下 : 
(1) 新 建 bookinfo.php 文件 ， 获 取 图 书 的 详细 信息 。 首 先 通 过 $_GET 全 局 数组 接收 查询 字符 串 bid 的 值 ， 


其 中 bid 代表 传递 到 该 页 面 的 ID 号 并 将 图 书 ID 保存 到 $arrayBrowserID 数组 中 ， 该 数组 用 于 保存 当前 用 户 所 浏 
览 的 图 书 ID， 然 后 构建 查询 语句 ， 应 用 数据 库 管理 类 中 的 executeSQL( 方 法 执行 查询 获取 指定 ID 的 图 书信 息 ， 
具体 代码 如 下 : 
require_once theaderphp' 
让 (isset($_GET[bid]) && $_GET[bid] !=") { // 获 得 查询 字符 串 bid 的 值 
S$bid = $_GET['bid"]: 
yelse{ 
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Sbid =$_POST['bid]: 


ee Sbid); 

@$adminDB->executeSQL("update tb_bookinfo set browsertime = browsertime+1 where id=" . $bid . "", $connID); // 更 改 图 书 被 浏览 的 次 数 

让 (isset($_SESSION['browserIDs]) && $_SESSION['browserIDs] (=") { /设置 用 户 浏览 过 图 书 的 ID 
SarrayBrowserID = explode('@'. $_SESSION[ browserIDs]); 


$i < count(SarrayBrowserID): $i ++) { 

if ($arrayBrowserID[$i] != " && $arrayBrowserID[$i] =— $bid) { 
Sflag = 1: 

i 


人 
让 (fag 一 0){ 
0 $_SESSION['browserIDs'] = $bid . '@'; 


} 
yelse{ 
$_SESSION['browserIDs] = $bid . '@'; 


SarrayBrowserBookids = explode('@', $_SESSION[browserIDs]): 
SarrayBrowserBooks = array(); 
for ($i= 0; $i < count($arrayBrowserBookids); $i ++) { 
if ($arrayBrowserBookids[$i] !=") { 
$tmpBookinfo = $adminDB->executeSQL("select id, bookname, bookimg from tb_bookinfo where id=" . $arrayBrowserBookids[$i] . "", 
S$connID); 
@ array_push($arrayBrowserBooks. $tmpBookinfo); 


} 
Ssmarty->assign('arrayBrowserBooks'. $arrayBrowserBooks): 
if(! isset($_GET['cctype']) || $_GET['cctype] —") { /获取 图 书 层次 类 别 标识 
证 (isset($_POST[cetype]) && $_POST['cctype] (=") { 
$cctype = $_POST['cctype']: 


}else{ 
$cctype =$_GET['cctype']; 

} 

$smarty->assign('cctype'. $cctype): 

Sbigtypes = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime", SconnID): 

S$smarty->assign('bigtypes'. $bigtypes): // 查 询 图 书 大 类 

S$smalltypes = $adminDB->executeSQL("select id, typename. bigtypeid from tb_smalltype order by addtime", $connID); /查询 图 书 小 类 

S$smarty->assign('smalltypes'. $smalltypes): 

S$bookinfo = $adminDB->executeSQL("select tb_bookinfo.id as bid. bookname. bookids. page. isbn. zs, bookce, bc. about directory, writer, pubname, 

pubtime, bookimg, typename. oldprice, newprice from tb_bookinfo. tb_pub. tb_smalltype where tb_bookinfo.pubid = tb_pub.id and 
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了 tb_bookinfo.smalltypeid = tb_smalltype.id and tb bookinfo id=" . $bid . "", $connID); // 获 得 图 书信 息 

Ssmarty->assign('bookinfo', $bookinfo); 

代码 说 明 : 

@ 这 里 将 用 户 所 浏览 过 的 图 书 ID 用 字符 “@” 连 接 保存 到 
SESSION 中 。 

@ 函数 array_push0 用 来 将 元 素 添加 到 指定 的 数组 中 。 

(2) 为 了 帮助 读者 选 购 套 系 图 书 ,制订 学 习 流 程 ， 在 制作 明 

日 科技 图 书 网 的 图 书 详细 信息 页 时 ， 增 加 图 书 组 合 购买 功能 ， 其 
效果 如 图 15.31 所 示 。 mkt, 

在 数据 库 中 使 用 tb_book 表 的 bookids 字段 将 组 合 购买 图 书 的 了 
ID 用 字符 “@” 连接 ， 在 bookinfo php 页 面 中 ， 首 先 使 用 函数 se 
explode0 将 组 合 ID 保存 到 数组 中 ， 然 后 使 用 for 循环 语句 遍历 该 数组 ， 根 据 该 数组 元 素 查 询 出 所 有 组 合 图 书信 
息 并 将 图 书信 息 保 存 到 $arrayZhBooks 数组 中 ， 最 后 将 该 数组 传递 给 模板 ， 在 模板 中 通过 section 语句 输出 所 有 
组 合 图 书信 息 ， 其 关键 代码 如 下 : 


SarrayBookids = cxplode( @, $bookinfo[O]['"bookids]); /使 用 字符 “@” 分 隔 组 合 图 书 ID 
SarrayZhBooks = 

S$zhIDs =S$bookinfoolfbid1 . '@’: 

for ($i= 0; $i < count($arrayBookids); $i++) { // 获 得 组 合 ID 图 书信 息 


if (SarayBookids[$i] =") { 
S$tmpBookinfo = $adminDB->executeSQL("select id, bookname, bookimg from tb bookinfo where id=" . $arrayBookids[$i] . "", $connID); 
array push(SarrayZhBooks, StmpBookinfo); 
S$zhIDs .= StmpBookinfool[id] ,@: 
} 
人 SzhIDs): 
Ssmarty->assign('arrayZhBooks', $arrayZhBooks); 
(3) 在 图 书 详细 信息 页 加 入 读者 评论 功能 ， 有 助 于 网 站 经 营 者 分 析 图 书 的 价值 ， 从 而 确定 图 书 在 站 点 中 的 
摆 放 位 置 ， 实 现 评论 功能 的 过 程 如 下 : 
@ 在 图 书 详细 信息 展示 的 模板 页 中 创建 form 表单 ， 将 用 户 评论 提交 到 bookinfo.php 页 面 ， 添 加 到 指定 的 
数据 表 中 。 
@ 在 bookinfo.php 页 面 中 读 取 图 书评 论 信 息 ， 并 且 将 评论 信息 在 模板 页 bookinfo.phtml 中 输出 。 同 时 在 模 
板 页 中 为 图 书评 论 信息 创建 “删除 ” 超 链接 ， 使 评论 的 发 布 者 可 以 删除 自己 的 评论 。 
本 实例 的 完整 代码 请 参考 本 书 光盘 ， 由 于 篇 幅 所 限 这 里 不 再 歼 述 。 


国 秘笈 心 法 


心 法 领悟 603: 内 容 简介 和 图 书目 录 之 间 的 切换 。 

在 图 书 详细 信息 展示 的 模板 页 中 ,通过 onmouseover 事件 调用 JavaScript 脚本 中 的 changeTab1() 方 法 实现 在 
内 容 简 介 和 图 书目 录 之 间 的 切换 ， 其 原理 是 通过 onmouseover 事件 调用 JavaScript 脚本 中 的 方法 ， 控 制 <div> 标 
签 样式 的 隐藏 和 展开 。 

应 用 的 过 程 中 ， 唯 一 需要 改动 的 就 是 filename， 即 将 filename 替换 为 要 下 载 的 文件 。 


国 实例 说 明 ， 清 阶 指 证 值 板 亚 县 的 
， 对 于 同一 个 变 县 你， 
在 明日 科技 图 书 网 的 主页 中 有 一 个 新 闻 公 告 展示 模块 ， 用 于 展示 明日 科技 网 站 发 ihe 
布 的 新 闻 公告 信息 ， 其 运行 效果 如 图 15.32 所 示 。 图 15.32 新 闻 公 告 
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图 关键 技术 


(1) 应 用 Smarty 模板 中 的 truncate 方法 对 新 闻 公告 的 标题 进行 截取 ， 并 以 “..” 蔡 换 被 截取 的 内 容 。 

(2) 应 用 Util 类 中 的 baseUr10 方 法 定义 文件 的 相对 路 径 ， 使 用 unHtml ($text) 方 法 对 输出 的 字符 串 进行 转 
义 ; 使 用 msubstr ($str, $start, Slen) 方 法 对 字符 串 进行 截取 ， 防 止 截取 中 文字 符 串 时 出 现 乱 码 ; 使 用 editorUnHtml 
($text) 方 法 对 编辑 器 编写 的 内 容 进行 转 义 。 


图 设计 过 程 


(1) 在 index.php 文件 中 ， 通 过 数据 库 管理 类 的 executeSQL0O 方 法 查询 公告 信息 表 中 的 数据 (查询 出 8 条 
记录 ) ， 并 且 将 查询 结果 赋 给 模板 变量 ， 其 关键 代码 如 下 : 

Stells = $adminDB->executeSQL("select id, title addtime from tb_tell order by addtime desc limit 0, 8", SconnID); 
Ssmarty->assign('tells', S$tells): 

(2) 在 index.phtml 模板 页 中 ， 通 过 section 语句 循环 输出 模板 变量 中 传递 的 公告 信息 ， 并 且 通 过 truncate 
方法 对 新 闻 公 告 的 标题 进行 截取 ， 控 制 其 输出 20 个 字 节 的 内 容 。 为 公告 标题 创建 查看 公告 详细 信息 的 超 链接 ， 
链接 到 tellinfo.php 文件 ， 传 递 的 参数 是 公告 的 ID 。 同 时 创建 more 超 链接 ， 链 接 到 tell.php 文件 ， 分 页 输出 所 有 
的 新 闻 公告 。index.phtml 模板 页 的 关键 代码 如 下 : 


<div style="width:187px; height:120px; border:1px solid #CCCCCC; float:right: -bottom:10px"> 
<div style="width:100%; height:21px; border: 1px solid #FFFFFF:; background: Ee gif):; text-align:left; color:#990000; 
padding-left:Spx"> 
<li style="display:inline: width:17px: height17px: background:url( {util->baseUrl} /img/mark_tell.gif): float:left"></li> <li style="float:left; 

padding:4px"> 新 闻 公 告 &nbsp:&nbspi&nbsp:&nbsp; <a href=" {util->baseUrl}/tell.html" class="a5">more</a></li> 

</div> 

{section name=tID loop=$tells} 

<div style="width:90%; text-align:left: padding-top:10px"> 

<a href=" {util- >baseUrl) /tellinfe {Stell: [UD] id} html" class="al"> {util->unHtml p=$tells[tID].titleltruncate:20:"..":false}</a> 

</div> 

{/section} 
</div> 


(3) 新 建 tellinfo.php 文件 ， 根 据 超 链接 传递 的 新 闻 公告 的 ID 值 执行 查询 操作 ， 查 询 出 指定 公告 的 详细 信 


息 ， 其 关键 代码 如 下 : 
ifisset(S_GET[tid]) && $_GET[tid]!="){ 
S$tid =$_GETItid]: 
jelsef 
S$tid =$_POST[tid]: 


Ssmarty->assign('tid', $tid); 

Stell = $adminDB->executeSQL("select id, title, content, addtime from tb_tell where id='$tid"™", $connID); 

S$smarty->assign('tell', $tell); 

S$smarty->display('tellinfo.phtml): 

在 tellinfo.phtml 模板 页 中 ， 输 出 指定 公告 的 详细 信息 ， 并 应 用 Util 类 中 的 方法 对 输出 的 内 容 进行 格式 化 操 


作 ， 其 关键 代码 如 下 : 
<div style="width:100%"> 
<div style="width:95%; height:35px; text-align:left; border-bottom: lpx dotted #333333; padding-top:12px: font-size:13px; color:#003399"> 
<li style="display:inline: width:450px; float:left"><strong> 主题 : {util->unHtml p=$tell[0].title}</strong></li> 
<li style="dispaly:inline: width:180px; float:right"> 发 布 时 间 : {util->msubstr p=$tell[0].addtime p1=0 p2=10}</li> 
</div> 
<div style="width:95%; text-align:left; padding-top:15px: line-height:20px: font-size:14px"> 
{util->editorUnHtml p=$tell[0].content} 
<div> 
</div> 
(4) 新 建 telLphp 文件 ， 应 用 分 页 类 中 的 pageData0 方 法 对 新 闻 公 告 信息 表 中 的 数据 进行 分 页 查询 。 在 
tell.phtml 模板 页 中 ， 完 成 新 闻 公 告 的 分 页 输出 ， 为 新 闻 公 告 标题 创建 超 链接 ， 链 接 到 tellinfo.php 文件 ， 查 看 公 


告 的 详细 信息 。 
国 秘笈 心 法 
心 法 领悟 604: 最 有 效 的 截取 中 文字 符 串 的 方法 。 
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在 本 实例 中 ， 运 用 了 两 种 截取 中 文字 符 串 的 方法 。 第 一 种 是 Smarty 模板 中 的 truncate 方法 ， 它 虽然 可 以 对 
中 文字 符 串 进行 截取 ， 但 是 同样 可 能 会 出 现 乱码 的 问题 ;第 二 种 是 自 定义 的 方法 msubstr0， 可 以 防止 截取 中 文 
字符 串 时 出 现 乱 码 ， 在 使 用 时 需要 传递 3 个 参数 ， 指 定 截取 的 字符 串 、 截 取 的 开始 位 置 和 截取 的 长 度 。 


155 站 内 搜索 


搜索 功能 是 一 个 很 重要 且 常 见 的 功能 。 一 个 好 的 搜索 引擎 能 给 用 户 的 使 用 带 来 方便 。 本 节 将 以 明日 科技 图 
书 网 站 中 的 一 般 搜索 和 高 级 搜索 为 例 ， 讲 解 搜索 功能 的 实现 方法 。 


力 实例 说 明 


在 明日 科技 图 书 网 站 的 头 文件 中 ， 设 计 了 一 个 查找 图 书 的 文本 框 ， 其 实现 的 就 是 一 般 搜 索 的 功能 。 在 本 实 
例 中 ， 按 图 书 名称 进 行 搜索 ， 输 入 PHP 关键 字 ， 单 击 “查找 图 书 ” 按 钮 ， 将 输出 如 图 15.33 所 示 的 内 容 。 
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力 关键 技术 


在 一 般 搜索 功能 中 ， 关 键 技术 是 应 用 explode() 函 数 对 查询 的 关键 字 进行 拆 分 返回 一 个 数组 。 然 后 通过 for 
循环 语句 读 取 这 个 数组 中 的 元 素 。 最 后 定义 select 查询 中 的 where 子 句 ， 以 数组 中 的 元 素 值 为 like 模糊 查询 的 
条 件 ， 其 关键 代码 如 下 : 


SarrayKeyWord = explode(' ', SkeyWord); // 使 用 空格 对 查询 的 关键 字 进行 拆 分 
Swhere =""; // 定 义 变量 
$j=0: 
for($i=0; $i<count(SarrayKeyWord): $i++){ 1/ 循环 读 取 查询 关键 字数 组 中 的 元 素 
if($arayKeyWord[$i]!="){ // 判 断 数 组 元 素 的 值 是 否 为 空 
if($j>0){ // 如 果 变 量 值 大 于 0 
Swhere .=" or ": // 定 义 where 变量 的 值 


} 
$where .=" tb_bookinfo.bookname like '%".$arrayKeyWord[$i]."%'": ”// 定 义 变量 的 值 ， 即 定义 查询 语句 的 where 子 句 
Sjtt; 
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图 设计 过 程 
(1) 在 headerphtml 模板 页 中 创建 form 表单 ， 将 查询 关键 字 提交 到 search.php 文件 ， 其 关键 代码 如 下 : 


<form name="form_search" method="post" action=" {util->baseUrl} /search html" onSubmit="return chkinputSimpleSearch(this)"> 
<div style="width:8px: height:36px: float:left; background-url( {util->baseUrl}/img/top_search left.gif)"></div> 
<div style="width:484px; height:36px; float:left; background:url({util->baseUrl}/img/top_search_center gif); text-align:left"> 
<li style="display:inline: height:35px: padding-top:5px"><input type="text" name="keyWord" size="40" class="inputl" value="{f 
Skeytxt!="} {$keytxt) {else} 请 输入 要 查询 的 图 书 名称 {/i" onMouseOver="this.select0"/></li> 
<li style="display:inline; height:35px; padding-top:5px; padding-left:Spx"><input type="hidden" name="stype" value="simple" /><input 
type="image" sre=" {util->baseUrl}/img/button_findbook.gif’ /></li> 
</div> 
<div style="width:8px; height:36px; float:right; background:url({util->baseUrl}/img/top_search_right.gif)"></div> 
</form> 


(2) 在 search.php 文件 中 获取 表单 提交 的 查询 关键 字 ， 并 对 查询 关键 字 进 行 拆 分 。 然 后 ， 定 义 查询 语句 的 
where 子 句 的 值 。 最 后 ， 定 义 多 表 查 询 语句 ， 以 where 子 句 为 查询 条 件 ， 应 用 分 页 类 中 的 pageData() 方 法 执行 分 
页 查询 ， 将 查询 结果 赋 给 模板 变量 ， 在 模板 页 中 分 页 输出 查询 结果 。 在 search.php 文件 中 ， 一 般 查询 的 关键 代 
码 如 下 : 


让 (isset($_POST[keyWord]) && trim($_POST[keyWord]!="){ // 判 断 查询 的 关键 字 是 否 为 空 
SkeyWord =$_POST[keyWord']; 
jelse{ 
SkeyWord = urldecode(str_replace('@', %', $_GET[keyWord'])); 
} 
SarrayKeyWord = explode(' ', $keyWord); // 使 用 空格 对 查询 的 关键 字 进 行 拆 分 
S$smarty->assign(key' str_replace('%%', '@, urlencode($keyWord))); // 将 关键 字 中 的 % 普 换 为 @， 并 赋 给 模板 变量 
Ssmarty->assign('arrayKeyWord', SarrayKeyWord); // 将 查询 关键 字数 组 赋 给 模板 变量 
if(isset($_POST['stype']) && trim($_POST['stype']!=")){ 1/ 判断 变量 stype 的 值 是 否 为 空 
S$stype = $_POST['stype']: 
jelse{ 
S$stype = $_GET['stype']: 
} 
$smarty->assign('stype’, $stype); // 将 其 赋 给 模板 变量 
- /定义 变量 
Si<count($arrayKeyWord); Sit+H){ // 循 环 读 取 查询 关键 字数 组 中 的 元 素 
if(SarrayKeyWord[$i]!="){ // 判 断 数 组 元 素 的 值 是 否 为 空 
if($j>0){ // 如 果 变 量 值 大 于 0 
Swhere .=" or "; /定义 where 变量 的 值 
4 
$where .=" tb_bookinfo.bookname like '%".$arrayKeyWord[$i]."%"; /定义 变量 的 值 ， 即 定义 查询 语句 的 where 子 句 
j++ 
} 
Swherel =""; // 定 义 高 级 搜索 的 where 子 句 变 量 


$sql = "select tb_bookinfo.id. tb_bookinfo.bookimg, tb_bookinfo.oldprice. tb_bookinfo newprice, tb_bookinfo.about, tb_bookinfo.browsertime, 
也 bookinfo.bookname. tb bookinfo.writer, tb bookinfo.pubtime, tb bookinfo.addtime. tb bookinfo ishave. tb pub.pubname from tb bookinfo, tb pub 


where tb_bookinfo.pubid =tb_pub.id and (".$where.") ".$wherel." order by tb_bookinfo.addtime desc"; // 定 义 查询 的 SQL 语句 
S$bookinfos = SpageDB->pageData($sql, $connID. 10. $page); /执行 分 页 查询 
$smarty->assign(‘bookinfos', $bookinfos); // 将 查询 结果 赋 给 模板 变量 


(3) 在 search.phtml 模板 页 中 ， 应 用 section 语句 分 页 输出 查询 结果 ， 代 码 请 参考 本 书 光盘 。 


国 秘笈 心 法 
心 法 领悟 605: explode0 函 数 详解 。 


explode0 函 数 用 于 将 字符 串 依 指定 的 字符 串 或 字符 separator 进行 拆 分 ， 返 回 值 为 数组 ， 其 语法 如 下 : 


array explode(string separator string string, [int limit]) 


该 函数 返回 由 字符 串 组 成 的 数组 ,每 个 元 素 都 是 string 的 一 个 子 串 ,被 字符 串 separator 作为 边界 点 分 隔 出 来 。 
如 果 设 置 limit 参数 ， 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 后 那个 元 素 将 包含 string 的 剩余 部 分 。 
如 果 separator 为 空 字符 串 〈"") ，explode0 函 数 将 返回 FALSE。 

如 果 separator 所 包含 的 值 在 string 中 找 不 到 ， 那 么 explode0 函 数 将 返回 包含 string 单个 元 素 的 数组 。 
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如 果 参 数 limit 是 负数 ， 则 返回 除 最 后 的 -limit 个 元 素 外 的 所 有 元 素 。 


实例 606 高 级 | 


趣味 指数 : 富 食 但 个 


图 实例 说 明 


在 明日 科技 图 书 网 站 的 高 级 搜索 功能 中 ， 可 以 输入 图 书 名 称 关键 字 、 作 者 、 出 版 社 、 类 别 和 出 版 时 间 ， 根 
据 这些 内 容 进 行 综合 查询 ， 高 级 搜索 的 运行 效果 如 图 15.34 所 示 。 


全 当 卫 打 位 午 ， 明日 所 上 韦 后 3》 十 重要 过 


豆 训 关 负 字 ， 国 本 要 《5 ， 技 图 书 名 称 模 和 正本， 子 十 关键 地 之 风月 宇 坟 分) 
[a EE ， 再 护 入 人 F 痢 包谷 关 刍 宁 ， 失 作者 名称 悍 册 下 取 ) 
| 


ua， re Ce rr Pr 
EE 时 -| 


15.34 ”高 级 搜索 表单 


图 关键 技术 


(1) 应 用 Smarty 模板 中 的 {ldelim} {rdelim} 标 签 在 Smarty 模板 页 中 直接 编辑 JavaScript 脚本 语句 。 
(2) 在 JavaScript 脚本 中 应 用 jQuery 技术 编写 图 书 类 别 展示 的 二 级 联动 菜单 ， 其 关键 代码 如 下 : 


<seript sre=" {util->baseUrl}/js/jqueryjs"></script> <[- 载 入 jQuery 库 -> 
<script language="javascript" > 
S$(document) ready( 
functionO {ldelim} 
S$("#bigtypeid").change(functionO {1delim} 
$.get(" futil->baseUrl}/getstype.php?stid="+$("#bigtypeid").val(), null, fanction(data) {1delim} 
SC"#smalltypeid").emptyO: 
S("#smalltypeid").append(data): 
{rdelim)}): 
{rdelim}); 
{rdelim} 
六 
</script> 
其 中 调用 getstype.php 文件 ， 定 义 图 书 类 别 中 子 类 的 下 拉 列 表 框 值 ，getstype.php 文件 的 代码 如 下 : 
<Iphp 
和 ‘zhine.php'; /包含 配置 文件 
Ssmalltypes = $adminDB->executeSQL("select id, typename from tb_smalltype where bigtypeid=".$_GETT'stid]."", $connID); 
a 


for($i = 0: $i < count($smalltypes); $i++){ // 将 从 数据 库 中 读 取 的 数据 添加 到 下 拉 列 表 的 选项 中 
$data ="<option value—\"".$smalltypes[Si][id"]."\">".iconv('gbk’. ‘utf-8'. $smalltypes[Si][typename'])."</option>"; 


a // 输 出 变量 值 ， 即 输出 下 拉 列 表 框 的 什 
(3) 应 用 Smarty 模板 中 的 html_options 方法 自 定义 函数 设置 日 期 的 下 拉 列 表 框 值 ， 其 部 分 代码 如 下 : 


<select name="fyear"> 
<option value=" selected>- 请 选择 -</option> 
{html options options = $arrayYear} 
</select>&nbsp: 年 
<select name="fmonth"> 
<option value=" selected>- 请 选择 -</option> 
{html_options options = $arrayMonth} 
</select>&nbsp: 月 &nbsp:-&nbsp:-&nbsp: 到 


(4) 定义 高 级 搜索 的 SQL 语句 ， 充 分 发 挥 where 子 句 的 作用 ， 通 过 多 表 查 询 完成 高 级 搜索 的 功能 。 


PHP 开发 实例 大 全 〈 基 础 卷 ) 
设计 过 程 
(1) 新 建 advancedsearch.php 文件 ， 定 义 高 级 搜索 form 表单 中 所 需要 的 内 容 ， 包 括 出 版 社 、 图 书 类 别 和 出 
版 时 间 ， 将 这 些 内 容 添加 到 模板 变量 中 ， 最 终 传递 到 模板 页 advancedsearch.phtml 中 。 
(2) 新 建 advancedsearch.phtml 模板 文件 ， 设 计 高 级 搜索 的 form 表单 ， 并 且 将 advancedsearch.php 文件 中 
传递 的 数据 添加 到 表单 元 素 中 ， 通 过 POST 方法 将 高 级 搜索 的 数据 提交 到 search.php 文件 中 进行 处 理 。 


(3) 在 search.php 文件 中 ， 根 据 表单 中 提交 的 数据 定义 select 查询 的 where 子 句 ， 最 终 编写 一 个 多 表 查 询 


的 SQL 语句 完成 高 级 搜索 的 功能 ， 其 关键 代码 如 下 : 
Swherel = // 定 义 高 级 搜索 的 where 子 句 变量 
if($stype — 'adv){ // 如 果 变 量 stype 的 值 为 adv， 则 说 明 是 高 级 搜索 
if(isset($_ POST['writer]) && trim($_POST['writer]!="){ 1/ 判断“ 作者 ”的 值 是 否 为 空 
S$writer = $_POST['writer]; 
jelsef 
$writer= urldecode(str_replace('@', %', $_GET[ writer’])); 
} 
Ssmarty->assign('writer, str_replace(9%6，@' urlencode($writer))); 
Swherel =" and tb_bookinfo.writer like %".Swriter "96 "; /where 子 句 ， 对 “作者 ”执行 模糊 查询 
if(isset($_POST['fyear]) && trim($_POST['fyear]!="){ // 判 断 开始 的 年 份 
Sfyear =$_POST['fyear]; 
jelsef 
Sfyear =$_GET['fyear']: 


S$smarty->assign('fyear, $fyear); 

if (isset($_POST['fmonth']) && trim($_POST[ fimonth]!="){ // 判 断 开始 的 月 份 
$finonth =$_POST[ fimonth']; 

jelsef 
$fimonth =$_GET['fmonth']: 


} 

Ssmarty->assign( fmonth', $fmonth); 

if(isset($_ POST[tyear]) && trim($_POST['tyear]!="){ // 判 断 截 止 年 份 
Styear =$_POST['tyear]: 

yelse{ 
Styear =$_GET['tyear]; 


} 

Ssmarty->assign('tyear’, $tyear); 

让 (isset($_POST[tmonth]) && trim($_POST['tmonth]!="){ // 判 断 截 止 月 份 
S$tmonth =$ POST[tmonth]; 

jelsef 
S$tmonth =$_GET[tmonth]; 


} 
S$smarty->assign(‘tmonth', $tmonth): 


Sfrompubtime = $fyear."-".$fimonth."-00"; 
StoPubtime = $tyear."-".$tmonth."-00"; 
Swherel =" and tb_bookinfo.pubtime > '$fromPubtime’ and tb_bookinfo pubtime < '$toPubtime' "; // 定 义 日 期 的 查询 条 件 
让 (isset($_ POST[pubid]) && trim($_POST['pubid]!="){ 
Spubid =$_POST[pubid]; 
jelsef 
$pubid =$_GET[pubid]; 


下 
Ssmarty->assign('pubid', Spubid); 


S$wherel = " and tb_bookinfo pubid ='$pubid ": /查询 出 版 社 

让 (isset($_POST[smalltypeid]) && trim($_POST['smalltypeid]!="){ // 判 断 小 类 
$smalltypeid = $_POST['smalitypeid]: 

jelsef 


$smalltypeid = $_GET['smalltypeid]: 
} 
S$smarty->assign('smalltypeid'. $smalltypeid): 
S$wherel = " and tb_bookinfo.smalltypeid ='$smalltypeid’ ": // 查 询 图 书 类 别 


} 
$sql = "select tb_bookinfo id. tb_ bookinfo bookimg. tb bookinfo oldprice. tb_bookinfo.newprice, tb_bookinfo.about. tb_bookinfo.browsertime, 
tb_bookinfo.bookname. tb_bookinfo writer tb_bookinfo.pubtime. tb_bookinfo.addtime, tb_bookinfo ishave. tb_pub pubname from tb_bookinfo, tb_pub 


where tb_bookinfo pubid =tb_pub.id and (".$where.") ".$wherel." order by tb bookinfo addtime desc"; // 定 义 查询 的 SQL 语句 
S$bookinfos = SpageDB->pageData($sql, $connID. 10. Spage): // 执 行 分 页 查询 
S$smarty->assign('bookinfos'. $bookinfos); // 将 查询 结果 赋 给 模板 变量 
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(4) 在 search .phtml 模板 页 中 应 用 section 语句 分 页 输出 查询 结果 ， 代 码 请 参考 本 书 光盘 。 


心 法 领悟 606: jQuery 框架 。 

jQuery 由 美国 人 John Resig 创建 ， 至 今 已 吸引 了 来 自 世界 各 地 的 众多 JavaScript 高 手 加 入 其 团队 。jQuery 
是 继 prototype 之 后 又 一 个 优秀 的 JavaScript 框架 ， 其 宗旨 是 WRITE LESS，DO MORE， 即 写 更 少 的 代码 ， 做 更 
多 的 事情 。 它 是 轻 量 级 的 js 库 ( 压 缩 后 只 有 21KB) ， 这 是 其 他 js 库 所 不 及 的 。 它 兼容 CSS3 以 及 各 种 浏览 器 
(IE 6.0+、FF 1.5+、Safari 2.0+、Opera 9.0+ 等 ) 。 

jQuery 是 一 个 快速 的 、 简 洁 的 JavaScript 库 ， 使 用 户 能 更 方便 地 处 理 HTML documents、events、 实 现 动画 
效果 ， 并 且 方 便 地 为 网 站 提供 AJAX 交互 。 

应 用 jQuery 技术 的 前 提 条 件 是 必须 在 项 目 中 载 入 jQuery 库 ， 否 则 无 法 调用 其 中 的 方法 。 


15.6 购 物 车 


购物 车 是 网 上 购物 时 使 用 的 一 个 临时 存储 商品 的 “车 辆 ”， 为 用 户 在 网 上 购物 提供 了 很 大 的 方便 ， 不 用 担 
心 一 次 购买 多 个 商品 时 要 进行 多 次 提交 结算 的 操作 ， 可 以 将 所 选 商品 放 入 购物 车 中 ， 等 选 购 完成 后 一 起 结算 ， 
购物 车 是 电子 商务 类 网 站 中 一 个 必 不 可 少 的 功能 。 本 节 将 以 明日 网 上 书店 中 的 购物 车 为 模板 ， 详 细 讲 解 购物 车 
的 实现 过 程 。 


En 
用 实例 说 明 


对 于 电子 商务 类 网 站 来 说 ， 安 全 、 稳 定 的 购物 车 模块 是 非常 重要 的 ， 该 模块 直接 关系 到 交易 是 否 能 够 顺利 
进行 。 为 了 提高 代码 的 可 移植 性 ， 在 制作 明日 科技 书店 购物 车 时 ， 将 购物 车 抽象 成 类 ， 封 装 到 library\Cartphp 
文件 中 。 购 物 车 功能 的 运行 效果 如 图 15.35 所 示 。 
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“在 大 网 条 时 ,请 下 要 末 用 如 的 =ockie 坟 持 - tT 
“ 购 天 国 书 这 各 中， 于 该 下 要 全 用 浏 和 关 工 具 攻 中 的 “后 朝 ” 定 甸 ， 尽 全 全 用 二 让 太 国内 地 二 的 号 类 失 这 样 可 以 H 目 四 上 委 各 人 让 


15.35 ”购物 车 的 运行 效果 


图 关键 技术 


在 购物 车 类 的 封装 中 ， 应 用 最 多 的 就 是 explode0 函 数 和 implode0 函 数 。 
(1) explode0 函 数 将 字符 串 用 指定 的 子 串 分 隔 ， 并 将 分 隔 结 果 保 存 到 数组 中 。 在 购物 车 类 的 addCart0 方 法 


中 ， 应 用 explode0 函 数 将 ID 串 用 “@ ”分隔 ， 并 将 分 隔 结果 保存 到 数组 中 ， 其 关键 代码 如 下 : 
S$armaylds = explode('@'. $this->idStr); /将 王 串 用 “@” 分 隔 ， 并 将 分 隔 结果 保存 到 数组 中 


(2) implodeO 函 数 将 指定 数组 中 的 所 有 元 素 使 用 特定 的 字符 进行 连接 形成 新 的 字符 串 ， 其 语法 如 下 : 


(865 


PHP 开发 实例 大 全 (基础 卷 ) 


string implode(string glue, array pieces) 


参数 glue 是 字符 之 间 的 分 隔 符 号 ; 参数 pieces 是 指定 的 数组 。 
在 购物 车 类 的 changeNum() 方 法 中 应 用 implode0 函 数 将 商品 ID 数组 以 “@” 为 分 隔 符 重 新 合并 成 一 个 ID 


串 ， 其 代码 如 下 : 
S$this->idStr = implode(\Q@', SarrayIds); /重新 全 并 成 ID 串 
S$this->numStr = implode('@', $arrayNums): /重新 合并 成 数量 串 


(3) unset0 函 数 销毁 指定 的 变量 或 数组 元 素 。 
在 购物 车 类 的 remove( 方 法 中 ,应 用 unset0 函 数 删 除 商品 人 D 数组 和 商品 数量 数组 中 的 指定 元 素 值 ， 其 代码 


如 下 : 
unset($arrayIds[$i]): 
unset(SarrayNums[$i]): 


// 删 除 该 元 素 
// 同 时 删除 该 商品 的 数量 


力 设计 过 程 
购物 车 类 Cart 的 实现 过 程 如 下 : 
(1) 定义 购物 车 类 的 属性 Sidstr 和 SnumStr， 分 别 用 来 表示 购物 车 中 存放 商品 的 ID 字符 串 和 数量 字符 串 ， 
并 分 别 用 字符 “@” 进 行 连接 ， 代 码 如 下 : 


var $idStr; /商品 并 组 成 的 字符 串 ， 用 字符 “@” 进 行 连接 
var $numStr; /商品 数量 组 成 的 字符 串 ， 用 字符 “@” 进行 连 接 


(2) 定义 购物 车 类 的 构造 方法 ， 用 来 对 商品 ID 串 和 商品 数量 串 赋 初 值 ， 代 码 如 下 : 
function Cart($idStr, $numStr){ 
Sthis->idStr = $idStr; // 为 DD 串 赋 初 值 


Sthis->numStr = $numStr; // 为 数量 串 赋 初 值 
} 
(3) 使 用 addCart0 方 法 将 商品 添加 到 购物 车 中 ， 其 关键 代码 如 下 : 
function addCart($goodsId, $goodsNum) { 
Sarraylds = explode('@", $this->idStr); /将 芽 串 用 “@” 分 隔 ， 并 将 分 隔 结果 保存 到 数组 中 
Sflag = 0; /商品 是 否 添加 标识 
for($i=0; $i <count($arrayIds); Sit+H){ // 判 断 商 品 是 否 已 经 在 购物 车 中 


if(SarrayIds[$i] 一 SgoodsId){ 
Sflag=1: 
} 


} 
if(Sflag — O){ 


// 如 果 该 商品 在 购物 车 中 ， 则 使 Sflag 的 值 为 1 


/如 果 $flag 的 值 为 0， 则 说 明 该 商品 不 在 购物 车 中 
Sthis->idStr = $goodsId . '@'; // 连 接 新 增 的 商品 ID 
Sthis->numStr = $goodsNum . '@'; // 连 接 新 增 的 商品 数量 


} else { 
echo "<script>alert(' 该 商品 已 经 添加 ! );</script>"; 


// 如 果 该 商品 已 经 在 购物 车 中 ， 则 给 出 提示 

} 

上 述 的 addCart0 方 法 包含 参数 $idStr 和 $goodsNum， 分 别 表示 新 增 商品 的 ID 和 数量 。 在 该 方法 内 部 ， 首 先 
通过 for 循环 语句 遍历 购物 车 中 已 经 存在 的 商品 ID， 如 果 新 增 ID 也 在 其 中 , 则 给 出 该 商品 已 经 在 购物 车 中 的 提 
示 信 息 ， 和 否则 将 该 商品 的 ID 以 及 购买 数量 分 别 连接 到 购物 车 类 的 ID 串 和 数量 串 中 。 

(4) 使 用 removeCart () 方 法 将 商品 移出 购物 车 ， 其 代码 如 下 : 


function removeCart(S 
Sarraylds = explode((@'、S$this->idstDj: 
SarrayNums = explode('@". $this->numStr): 


// 将 商品 D 串 用 “@” 分 隔 成 数组 
// 将 商品 数量 串 用 “@” 分 隔 成 数组 


for($i= 0; $i < count(SarrayIds); $i++){ // 遍 历 商品 功 串 
if($arraylds[$i] 一 $goodsId){ // 如 果 查 找到 与 要 删除 商品 ID 相同 的 数组 元 素 
unset($arrayIds[$i]): 1/ 删除 该 元 素 
unset($arrayNums[$i]): // 同 时 删除 该 商品 的 数量 
由 
i 
S$this->idStr = implode('@'. $arrayIds): /重新 将 商品 ID 和 数量 数组 连接 成 字符 串 


Sthis->numStr = implode( @'. $arrayNums); 
} 


TemoveCart() 方 法 中 只 有 $goodId 一 个 参数 ， 表 示 要 移 除 商 品 的 人 D 号 。 在 该 方法 内 部 ， 首 先 将 商品 ID 串 用 
字符 “@ ”分隔 ， 并 将 分 隔 结果 保存 到 数组 中 ， 然 后 通过 for 循环 语句 遍历 数组 ， 如 果 在 数组 中 查找 到 与 要 删除 


866 
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商品 ID 相同 的 ID 号 ， 则 使 用 函数 unset0 将 数组 元 素 销毁 ， 然 后 再 将 数组 中 所 有 元 素 重新 用 字符 “@ ”连接 成 
商品 ZD 串 ， 这 样 就 可 以 实现 将 指定 的 商品 从 购物 车 中 移 除 的 操作 。 
(5) 使 用 changeNum0 方 法 更 改 购物 车 中 商品 的 数量 ， 其 代码 如 下 : 


function changeNum($goodsId, SgoodsNum){ 
Sarraylds = explode('@', $this->idStr): // 将 商品 人 D 串 用 “@” 分 隔 成 数组 
S$arrayNums = explode('@', $this->numStr); // 将 商品 数量 串 用 “@” 分 隔 成 数组 
for($i= 0; $i < count($arrayIds): $i++){ // 遍 历 商 品 作 串 
if ($arraylds[$i] — $goodsId){ // 如 果 查 找到 要 更 改 的 ID 
SarrayNums[$i] = $goodsNum: /更 改 数量 
1 
} 
Sthis->idStr = implode('@', $arrayIds); /人 重新 合并 成 ZD 串 
S$this->numStr = implode(@' SarrayNums); // 重 新 合并 成 数量 串 


} 

changeNum0 方 法 中 包含 两 个 参数 ， 分 别 为 要 更 改 的 商品 ID 号 和 要 更 改 的 数量 。 在 该 方法 内 部 ， 首 先 使 用 
函数 explode0 将 商品 ID 串 和 商品 数量 串 用 “@” 进 行 分 隔 ， 并 将 分 隔 的 字 串 分 别 保存 到 数组 中 ， 然 后 通过 for 
循环 语句 遍历 商品 ID 数组 ， 在 其 中 查找 要 更 改 数量 的 商品 ID， 查 找到 后 ， 将 新 数量 值 赋 给 数量 串 中 对 应 的 数 
组 元 素 ， 最 后 使 用 函数 implode0 将 商品 ID 数组 和 商品 数量 数组 中 的 所 有 元 素 分 别 重新 用 字符 “@” 进 行 连接 ， 
组 成 新 的 商品 ID 串 和 商品 数量 串 。 

(6) 通过 Cart 类 的 setCartNull0 方 法 ， 清 空 购物 车 中 的 商品 。 实 现 清空 购物 车 中 商品 的 操作 ， 只 需 将 商品 
ID 串 和 商品 数量 串 赋 为 空 值 即 可 ， 其 代码 如 下 : 


fanction setCartNull){ 
Sthis->idStr ="; // 清 空 商品 人 串 
S$this->numStr ="; // 清 空 商品 数量 串 


} 
(7) 通过 购物 车 类 中 的 方法 完成 对 商品 ID 串 和 商品 数量 串 的 操作 后 ， 还 需要 定义 两 个 方法 ， 分 别 用 来 获 


取 商 品 ID 串 和 商品 数量 串 ， 其 代码 如 下 : 
function getIdStrO{ /获得 购物 车 的 商品 ID 串 
return $this->idStr: 


} 
function getNumStrO{ 1/ 获得 购物 车 的 商品 数量 串 
retum $this->numStr; 


} 
以 上 讲解 了 明日 科技 书店 购物 车 功能 的 Cart 类 的 属性 和 主要 方法 ， 其 存储 于 library\Cart.php 文件 中 。 
国 秘笈 心 法 


心 法 领悟 607: 解析 购物 车 类 中 的 商品 ID 串 和 数量 串 。 
购物 车 类 中 的 商品 ID 串 和 商品 数量 串 是 指 用 字符 “@” 连 接 的 多 个 商品 的 ID 号 和 数量 值 ， 其 目的 是 使 用 
一 个 变量 或 者 数据 表 中 的 一 个 字段 存储 多 个 商品 的 ID 或 数量 。 


高 级 | 


实例 608 趣味 指数 : obodolod 


力 实例 说 明 


购物 车 的 主要 功能 是 保留 用 户 选择 的 商品 信息 。 用 户 可 以 在 购物 车 内 设置 选 购 商品 的 数量 、 显 示 选 购 商品 
的 总 金额 ， 还 可 以 进行 清除 选择 的 全 部 商品 信息 、 重 新 选择 商品 信息 等 操作 。 在 实例 607 中 已 经 讲解 了 购物 车 
类 的 实现 过 程 ， 本 实例 将 在 此 基础 上 介绍 购物 车 的 页 面 设计 和 功能 实现 ， 其 中 明日 科技 书店 的 购物 车 运行 效果 
如 图 15.36 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 
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图 15.36 明日 科技 书店 购物 车 运行 效果 


图 关键 技术 


购物 车 功能 实现 的 前 提 是 为 每 位 用 户 发 放 一 辆 购物 车 ， 即 为 每 位 用 户 定义 一 个 商品 ID 串 和 商品 数量 串 ， 并 
将 其 保存 在 $_SESSION 全 局 数组 中 。 

所 以 在 购物 车 功能 实现 的 cartphp 文件 中 ， 首 先 要 初始 化 SESSION 变量 ， 判 断 是 否 已 经 设置 了 用 于 保存 商 
品 了 D 串 的 $_ SESSION[sidstr] 数 组 元 素 ， 以 及 保存 商品 数量 串 的 $_ SESSION[mumstr] 数 组 元 素 。 如 果 没有 设 定 ， 
说 明 是 第 一 次 将 商品 添加 到 购物 车 中 ， 则 设置 这 两 个 数组 元 素 的 值 为 空 。 然 后 对 购物 车 类 Cart 进行 实例 化 ， 以 


便 继续 对 购物 车 中 的 商品 进行 增 、 删 、 改 操作 ， 其 关键 代码 如 下 : 
require_once ‘header. php'; // 包 含 网 站 头 文件 以 及 配置 文件 ， 在 配置 文件 中 初始 化 SESSION 变量 
if(! isset($_SESSION['idStr']) | ! isset($_SESSION['numStr])) { 
$_SESSION['idStr] ="; 
$_SESSION['numStr] ="; 
} 
S$cart =new Cart($_SESSION[idstr].$_SESSION[mumstr]); 


这 是 购物 车 功能 实现 的 前 提 条 件 ， 只 有 满足 了 上 述 条 件 ， 才 能 够 继续 执行 购物 车 中 的 增 、 删 、 改 等 功能 。 
图 设计 过 程 

下 面 在 购物 车 类 的 基础 上 讲解 购物 车 各 个 功能 的 实现 过 程 ， 其 操作 在 cart.php 文件 中 进行 

(1) 有 关 购 物 车 的 分 配 已 经 在 关键 技术 中 讲解 ， 这 里 不 再 熬 述 。 

(2) 应 用 购物 车 类 的 addCart0 方 法 将 商品 添加 到 购物 车 ， 其 传递 的 参数 值 分 别 为 购买 商品 的 ID 和 购买 商 
品 的 数量 ,将 商品 成 功 添加 到 购物 车 后 ， 还 需要 使 用 购物 车 类 的 getIdStr0 和 getNumStr0) 方 法 分 页 获取 经 购物 车 


类 处 理 后 的 商品 ID 串 和 商品 数量 串 , 将 获取 结果 分 别 赋 给 $_SESSION 全 局 数组 中 对 应 保存 商品 ID 串 和 商品 数 
量 串 的 数组 元 素 ， 实 现 购物 车 中 商品 刷新 效果 ， 商 品 添加 的 代码 如 下 : 


这 St 一 'add) { // 判 断 操 作 类 型 
S$cart->addCart($_GET[bid] 1); /调用 购物 车 类 的 addCart0 方 法 将 商品 添加 到 购物 车 中 
$_SESSION['idStr] = $cart->getIdStr(); // 获 取 商 品 人 D 串 
$_SESSION['numStr] = $cart->getNumStr(); // 获 取 商 品 数量 串 


} 
(3) 在 实例 607 中 已 经 介绍 过 ， 可 以 将 与 某 本 图 书 相关 的 所 有 图 书 批量 添加 到 购物 车 中 , 其 原理 是 : 首先 ， 
通过 explode0O 函 数 将 保存 组 合 图 书 ID 的 字符 串 用 字符 “@ ”分 隔 ， 并 将 分 隔 结果 保存 到 数组 中 ， 这 样 该 数组 的 
每 个 元 素 为 各 本 组 合 图 书 的 ID 号 。 然 后 ， 通 过 for 循环 遍历 数组 ， 在 遍历 过 程 中 分 别 通过 购物 车 类 的 addCartO) 
方法 将 图 书 添加 到 购物 车 中 ， 其 具体 实现 代码 如 下 : 


这 St 一 'gAdd){ // 判 断 操作 类 型 ， 如 果 为 gAdd 表示 组 合 添加 
S$arrayGIds = explode('@', $, GET[ids]): ID 并 将 结果 保存 到 数组 中 
for($i=0: $i<count($arrayGIds); $i++){ 遍历 数组 

if($arrayGIds[$i]!=" && !in_array($arrayGIds[$i]. explode(@'S ys 
S$cart->addCart(SarrayGIds[$i] .1): 7 分别 将 得 图 书 汪 加 到 购物 车 中 
} 
$_ SESSION[idstr] = $cart->getIdStr(): /重新 为 商品 ID 串 的 SESSION 变量 赋值 
$_SESSION['numStr'] = $cart->getNumStr(): // 重 新 为 商品 数量 串 的 SESSION 变量 赋值 
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(4) 应 用 购物 车 类 的 removeCart0 方 法 将 指定 的 商品 从 购物 车 中 移出 ， 其 传递 的 参数 值 是 商品 ID。 指 定 商 
品 删除 成 功 后 ， 分 别 为 保存 商品 ID 串 和 商品 数量 串 的 $_SESSION 全 局 数组 重新 赋值 ， 实 现 刷 新 购物 车 的 效果 ， 


其 实现 代码 如 下 : 
if($t — Temove){ // 判 断 当 前 操作 是 否 为 删除 操作 
$cart->removeCart($_GET[rbid]): /| 调用 购物 车 类 的 removeCart0 方 法 删除 指定 的 图 书 


$_SESSION['idStr] = $cart->getIdStr():; 
$_SESSION['numStr] = $cart->getNumStr(); 


了 
(5) 在 实现 更 改 商 品 数 量 的 功能 时 ， 由 于 商品 数量 是 由 顾客 录入 的 ， 在 进行 更 新 商品 数量 逻辑 前 ， 应 首先 
判断 录入 的 数字 是 否 合法 ， 如 果 不 合 法 则 给 出 提示 并 要 求 顾客 重新 填写 要 更 改 的 购买 数量 ， 成 功 通过 验证 后 ， 


应 用 购物 车 类 的 changNum() 方 法 实现 更 改 购物 车 中 商品 的 业务 逻辑 ， 其 实现 代码 如 下 : 
if($t == update’) { // 如 果 $t 的 值 为 update， 则 进行 更 新 操作 
Schangenum =$_ GET['num’]; // 获 得 要 更 新 图 书 的 数量 
if(!is_numeric($changenum) || intval($changenum) <= 0 || floor($changenum)!=$changenum){ 。“” // 判 断 数量 是 否 为 数字 
echo "<script>alert(' 购 买 图 书 的 数量 只 能 为 正 整数 ! );</seript>"; 


jelse{ 
/调用 购物 车 类 的 changeNum0 方 法 实现 更 改 购买 数量 
Scart->changeNum($_GET['ubid], $changenum): // 更 新 购买 图 书 数量 
$_SESSION['idStr] = $cart->getIdStr(); 
$_SESSION['numStr] = $cart->getNumStr(): 
} 


} 
(6) 应 用 购物 车 类 的 setCartNull0 方 法 清空 购物 车 中 商品 ， 调 用 该 方法 清空 购物 车 后 ， 需 要 重新 为 保存 商 
品 ID 串 和 商品 数量 串 的 $_SESSION 全 局 数组 赋值 ， 其 实现 代码 如 下 : 
ifst 一 clearAl) { /如 果 $t 为 clearAll 则 表示 进行 清空 购物 车 操作 
Scart->setCartNull0: /调用 购物 车 类 的 setCartNull0 方 法 清空 购物 车 
$_SESSION['idStr] = $cart->getIdStr(): 
$_SESSION['numStr] = $cart->getNumStr(); 
} 
(7) 完成 购物 车 中 商品 的 增 、 删 、 改 操作 后 ， 还 需要 根据 8_SESSION['idStr'] 数 组 元 素 从 数据 库 中 查询 出 购 


物 车 中 各 本 图 书 的 信息 ， 并 对 每 本 图 书 进行 价格 小 计 ， 对 购物 车 中 所 有 图 书 进行 价格 汇总 ， 最 终 将 统计 的 数据 
存储 到 指定 的 模板 变量 中 ， 其 具体 实现 代码 如 下 : 


S$arrayIds = explode('@', $_SESSION['idStr']): // 分 隔 商 品 ID 串 为 数组 
$arrayNums = explode('@', $_SESSION['numStr']): // 分 隔 商 品 数量 串 为 数组 
SarrayCarInfos = array(); // 保 存 购物 车 信息 的 数组 
StotalPrice = 0; /购物 车 图 书 总 价格 


for($i= 0; $i < count($arrayIds): $i++){ 
S$bookid = $arrayIds[Sil; 
if($bookid (="){ 


S$tmpArray = array(); 
// 获 得 购物 车 每 本 图 书 的 信息 

$bookinfo = $adminDB->executeSQL("select id, bookname .oldprice. newprice from tb_bookinfo where id=".$bookid.™", $connID); 

StmpArray[id] = Sbookinfo[ol[id]: 
$tmpArray[bookname] = $bookinfo[0]['bookname']: 

$tmpArray['oldprice'] = $bookinfofolroldprice1: 

S$tmpArray[mewprice] = Sbookinfo[0][mewprice]: 

StmpArray['num'] = $arrayNums[$i]: 

S$tmpArray['smallTotalPrice'] = Sbookinfo[o][mewprice] * SarrayNums[Si]; 

StotalPrice += $tmpArray['smallTotalPrice']: 1/ 计算 图 书 总 价 
array_push($arrayCarInfos, $tmpArray): // 将 每 本 图 书信 息 保存 到 数组 中 
} 
} 
Ssmarty->assign('arrayCarInfos'. $arrayCarInfos); 
S$smarty->assign('totalPrice'. $totalPrice); 
iflisset($_SESSION['une']) && $_SESSION['unc]!="){ // 判 断 用户 是 否 登 录 
Ssmarty->assign('isLogin'. "T"); 
smarty->assign('isLogin', 'F"); 
iflisset($ SESSIONTtoUrIT){ 
unset($_SESSION[toUrl]): 


jelsef 
$: 


} 
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$_SESSION[toUrl] = 'getbuyuserinfo.html’; 
(8) 在 views 文件 夹 下 新 建 cart.phtml 模板 页 ， 完 成 购物 车 页 面 的 设计 。 
图 秘笈 心 法 


心 法 领悟 608: 判断 指定 的 数据 是 否 为 正 整数 。 

判断 指定 的 数据 是 否 为 正 整数 ， 应 用 到 3 个 函数 : is_numericO、intval0 和 floor()。 

is_numericO) 函 数 检 测 变量 是 否 为 数字 或 者 数字 字符 串 ， 如 果 是 则 返回 TRUE， 和 否则 返回 FALSE。 

intval0 函 数 获取 变量 的 整数 值 。 

floor0 函 数 利用 使 去 法 获取 变量 的 整数 值 。 

在 过 条 件 语句 中 ,判断 is_numeric0 函 数 的 返回 值 是 否 为 TRUE， 判 断 intval0 函 数 的 返回 值 是 否 大 于 0， 判 
断 floor0 函 数 的 返回 值 与 变量 值 是 否 相 等 。 当 满足 is_numericO 函 数 的 返回 值 为 TRUE，intval0 函 数 的 返回 值 大 


于 0， floor0 函 数 的 返回 值 与 变量 值 相 等 时 ， 6 党 盟 变量 是 正 整 数 否则 说 明 不 是 正 整数 ， 其 应 用 方法 如 下 : 
if(! is_numeric(Schangenum) | intval($changenum) <= 0 | floor($changenum) != $changenum) { 
echo 六 拓 天 加 的 如 时 只 对 大 下 业 直 ;</seript>"; 


其 中 变量 Schangenum 为 要 验证 的 变量 。 
15.7 图 书 订 单 处 理 


为 了 方便 用 户 购买 图 书 促进 图 书 销售 ， 在 开发 明日 科技 图 书 网 时 特别 设立 图 书 订单 处 理 模块 ， 通 过 该 模块 
用 户 可 以 方便 地 订购 图 书 并 进行 在 线 支付 。 本 节 将 对 明日 科技 书店 图 书 订单 处 理 模块 进行 讲解 。 


加 we 


力 实例 说 明 

为 了 能 够 将 用 户 所 购买 的 图 书 顺利 邮寄 到 用 户 手中 ， 在 用 户 选择 好 购买 的 图 书后 还 需要 填写 收 货 人 信息 ， 
明日 科技 图 书 网 用 于 填写 收 货 人 信息 的 页 面 如 图 15.37 所 示 ， 在 该 页 面 中 ， 用 户 需 要 填写 个 人 的 真实 联系 信息 、 
收 货 方式 等 内 容 ， 如 果 需 要 发 票 ， 还 需要 填写 发 票 抬头 。 


Cl 


《< 人生 不 芝 人 地 直 ) 
Cp 00 


《图 宇 或 动 志 话 的 可 ， 固 二 只 证 站 TD 号 ) 


证 直 本 ， 丙 让 国 
本 人 ， 请 失 条 0431- 8497991 电 话 ， 扩 痢 上 


| cme) 
eg 

入 

B 

”共通 此 送 《省 -0 天 ， 瑞 扩 时 间 的 Xi 到 ,区 持 醒 $ 一 一 aol 市) 

ms 的 进 《中 用 可 元 ， 廊 持 国内 ) 

| 癌 天下， 河上 

Et 《* 汪 器 让 天 于， 和 5 村 各 包 所 二 信息 经 宅 开 娄 责 ) 


sr 
图 15.37 填写 收 货 人 信息 的 页 面 


图 关键 技术 


(1) 在 填写 收 货 人 信息 的 form 表单 中 ， 通 过 onsubmit 事件 调用 chkinputbuyuserinfo( 方 法 对 用 户 填写 的 信 
息 进 行 验证 ,同时 在 每 个 表单 元 素 中 通过 onBlur 事 件 调用 chkinputbuyuserinfo() 方 法 实现 对 元 素 值 的 无 刷新 验证 ， 
通过 <div> 标 签 直接 返回 验证 结果 。 

chkinputbuyuserinfo() 方 法 存储 于 js\fun.js 脚本 文件 中 ， 其 关键 代码 如 下 : 


function chkinl serinfo(form, mark){ 
Dae 


chkusemame innerHTML = <font color=#990000'>，。</font>&nbsp;&nbsp: 请 输入 收 货 人 姓名 !" 
om usemame .style = "#FF0000"; 
retumn false; 


innerHTML = 
chkusemame.style.display = ‘none’; 
form.usemame.style.backgroundColor = "A#FFFFFF"; 
} 


} 
/省 略 了 部 分 代码 
证 (form .but_showttchecked && (mark 一 5 || mark — "all")) { 
if(fom.tt.value —"") { 
chktt.innerHTML = "<font color=#990000'>。 </font>&nbsp;&nbsp; 请 输入 发 票 抬头 !"; 
chktt.style.display = "; 
form.tt.style.backgroundColor = "#FF0000"; 
Teturn false; 
}else{ 
chkttinnerHTML =""; 
chktt.style.display = 'mone': 
form.tt.style.backgroundColor = "#FFFFFF":; 


} 


Teturn true; 


} 
(2) 控 制 是 否 需要 填写 发 票 的 抬头 是 在 复 选 框 but_showtt 中 , 通过 onclick 事件 调用 isShowtt0 方 法 完成 的 。 
在 isShowtt0 方 法 中 ， 控 制 showtt 标签 style 样式 的 隐藏 和 展示 ， 完 成 发 票 抬头 文本 框 的 输出 和 隐藏 操作 。 
(3) 在 模板 页 中 通过 Smarty 中 的 $smarty.session 标签 获取 SESSION 变量 的 值 。 


图 设计 过 程 
(1) 在 views 文件 夹 下 新 建 getbuyuserinfo.phtml 模板 页 ， 设 计 提交 收 货 人 信息 的 form 表单 ， 并 将 数据 提 
交 到 getbuyuserinfo.php 文件 中 ， 存 储 到 SESSION 变量 中 。 


(2) 新 建 getbuyuserinfo.php 文件 ， 获 取 表单 中 提交 的 收 货 人 信息 ， 将 其 存储 到 $_SESSION 全 局 数组 中 ， 
这 样 做 的 目的 是 便于 用 户 在 订购 过 程 中 对 信息 进行 修改 ， 其 代码 如 下 : 


require_once ‘header.php' 
if(isset($_] Ss ]) && $_ POST[usemame] (=") { 1/ 判断 用 户 是 否 提 交 了 表单 
$_SESSION['recuserinfo][usemame]= $_ POST[usemame]: /将 用 户 信息 保存 在 SESSION 中 


$_SESSION[recuserinfo][idstr]=$ SESSION[idstr]: 

$ SESSION[recuserinfo' numstr1=$ SESSIONToumste1: 
$rect==$ POST[rectype]: 

0 1 < 1 { 


} a ee = 2 { 


= 
. ES 3){ 
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Srecpay = 20: 
Ge OU 
Srecpay = 


$_SESSION['recuserinfo']['recpay’] = $recpay: 
echo "<script>window.location href=" . Sutil->baseUrlO . "/deforder html';</script>"; // 重 新 定向 到 deforder.html 页 面 
exit|; 

} 

Ssmarty->display( getbuyuserinfo phtml): 

Tequire_once footerphp': 


图 秘笈 心 法 


心 法 领悟 609: 在 Smarty 模板 中 直接 获取 SESSION 变量 的 值 。 
在 Smarty 模板 中 直接 获取 SESSION 变量 的 值 , 应 用 的 是 Smarty 模板 中 的 $smarty.session 标签 。 首先 在 PHP 
动态 页 中 定义 SESSION 变量 ， 其 格式 如 下 : 


$_SESSION['recuserinfo']['username'] =$ POST[usemame']: 
$_SESSION['recuserinfo']['sex'] =$_POSI[sex]: 

然后 在 Smarty 模板 页 中 ， 通 过 如 下 方法 获取 SESSION 变量 的 值 : 
$smarty.session recuserinfo usemame 

$smarty.session recuserinfo .sex 


目 
赵 味 指数 : 请 良 育 家 


力 实例 说 明 


用 户 填写 完 收 货 人 信息 后 将 进入 订购 信息 确认 页 面 ， 如 图 15.38 所 示 ， 在 该 页 面 中 可 以 查看 并 确认 用 户 所 
订购 图 书 的 名 称 、 单 价 、 总 价格 和 收 货 人 的 信息 。 


便 购物 注 明 和 和 
Waa Ey aaanaaan 


图 书 名 称 空 员 价 《 兄 ; 数量 (本 : 芥 格 十 计 【 兄 ) 


图 15.38 确认 订购 信息 


图 关键 技术 


确认 订购 信息 功能 的 实现 , 首先 应 用 的 是 explode() 函 数 对 商品 ID 串 和 商品 数量 串 中 的 数据 进行 读 取 , 然后 
根据 返回 的 数组 元 素 值 从 数据 库 中 读 取 图 书信 息 ， 完 成 图 书 价格 的 汇总 。 

在 deforder.phtml 模板 页 中 ， 通 过 section 语句 循环 输出 用 户 购买 的 图 书信 息 ， 并 且 通 过 $smarty.session 标签 
输出 收 货 人 的 信息 。 上 述 方法 都 已 经 在 前 面 的 实例 中 讲解 过 ， 这 里 不 再 歼 述 。 


图 设计 过 程 
(1) 为 了 使 图 书 订购 流程 的 业务 逻辑 更 加 方便 ， 将 购物 车 和 收 货 人 的 信息 保存 到 SESSION 中 ， 所 以 显示 
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用 户 订购 信息 只 需要 提取 保存 在 SESSION 中 的 对 应 内 容 即 可 ，deforderphp 文件 的 代码 如 下 : 


require_once ‘header.php'; 
Sarraylds = explode((@',$ SESSION[recuserinfo][idstr]): /分隔 ID 串 并 将 结果 保存 到 数组 中 


SarrayNums = explode('@". $_SESSION['recuserinfo']['numStr ]): // 分 隔 数量 串 并 将 结果 保存 到 数组 中 
SarrayCarInfos = array(); // 定 义 数组 用 于 保存 图 书信 息 
StotalPrice = 0: /保存 图 书 总 价 
for ($i = 0; $i < count($arrayIds); $i++) { // 通 过 循环 保存 购物 车 中 每 本 图 书信 息 到 数组 
S$bookid = $arrayIds[$i]; 
if($bookid =") { 
StmpArray = array0: 


$bookinfo = $adminDB->executeSQL("select id, bookname .oldprice, newprice from tb_bookinfo where id=" . $bookid . "", $connID): 
StmpArrayfid]= $bookinfo[O][id]: 


StmpArray['num'] = $arayNums[$i]; 
S$tmpArray['smallTotalPrice'] = Sbookinfo[0][mewprice] * $arrayNums[$i]; 
$totalPrice += $tmpArray['smallTotalPrice']: 
array_push($arrayCarInfos, $tmpArray); 
S$smarty->assign(‘arrayCarInfos', $arrayCarInfos); 
Ssmarty->assign('totalPrice’, $totalPrice); 
$_SESSION['recuserinfo']['bookprice'] = StotalPrice: /图 书 总 价 
$_SESSION[Yrecuserinfo'][recpayall] = StotalPrice + $_SESSION[recuserinfo][recpay]; /图 书 总 价 和 邮递 费用 
Ssmarty->display(deforderphtml; 
Tequire_once ‘footer.php’; 
(2) 新 建 模板 文件 deforderphtml， 根 据 模板 变量 传递 的 值 输出 确认 订购 信息 ， 其 部 分 代码 如 下 
<div style="width:800px: height:25px"> 
<li style="display:inline; height:25px; text-align:left; width:100%"> 订 购 用 户 昵称 {$smarty.session.recuserinfo.unc}</li> 
<li style="display:inline; height25px text-align:left; width:50%"> 收 货 人 姓名 : {$smarty.session.recuserinfo.usermame} </li> 
<li style="display:inline; height:25px text-align:left; width:5096"> 性 别 : {$smarty.session.recuserinfo.sex}</li> 
<li style="display:inline; height:25px: text-align:left; width:100%"> 收 货 人 详细 地 址 ， {$smarty.session.recuserinfo.address}</li> 
<li style="display:inline; height:25px; text-align:left; width:50%"> 邮 政 编码 ， {$smarty.session.recuserinfo.yb}</li> 
<li style="display:inline; height:25px; text-align:left; width:50%"> 联 系 电话 {$smarty.session.recuserinfo.tel}</li> 
<li style="display:inline; height:25px; text-align:left; width:50%; float:left"> 发 票 抬头 。 {if $smarty.session.recuserinfo.tt=="} 不 要 发 票 
{else} {$smarty.session.recuserinfo.tt} {/if}</li> 
</div> 


国 秘 稚 心 法 


心 法 领悟 610: array_push0 〇 函数 详解 。 
array_push() 函 数 将 数组 当成 一 个 栈 ， 并 将 传 入 的 变量 压 入 该 数组 的 末尾 ， 该 数组 的 长 度 将 增加 入 栈 变量 的 
数目 ， 返 回 数组 新 的 单元 总 数 ， ee 


int array_push (array array, mixed var [, mixed ..]) 

参数 说 明 : 

array: 必 选 参数 ， 指 定 输入 的 数组 。 

var: 必 选 参数 ， 指 定 输入 数组 中 的 值 。 

在 本 实例 中 ， 通 过 array_push0 函 数 将 从 数据 库 中 读 取 的 数据 以 及 图 书 的 单 品 价格 添加 到 一 个 新 的 数组 中 ， 
生成 一 个 二 维 数组 ， 并 且 将 这 个 数组 值 赋 给 模板 变量 ， 在 模板 页 中 通过 section 语句 读 取 。 


守 高 级 : 
实例 611 趣味 指教 : 良 庚 良家 | 


国 实例 说 明 


用 户 确认 订购 信息 和 收 货 人 信息 无 误 后 ， 就 可 以 选择 支付 方式 ， 在 明日 科技 图 书 网 的 支付 方式 模块 中 ， 主 
要 提供 银行 汇款 、 支 付 宝 支付 和 工行 在 线 支付 3 种 方式 。 在 选择 支付 方式 页 面 中 ， 单 击 支付 宝 支付 的 “支付 ” 
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超 链接 ， 将 跳 转 到 如 图 15.39 所 示 的 页 面 ， 输 出 本 次 图 书 订购 的 订单 号 、 支 付 方式 和 需要 支付 的 总 金额 。 


了 消 可 殉 】 [退出 营 孙 ] 


图 15.39 支付 宝 在 线 支 付 
如 果 单 击 图 15.39 中 的 “已 经 确认 订购 信息 按 选择 支付 方式 支付 ” 按钮, 将 跳 转 到 支付 宝 页 面 完 成 支付 操作 。 


图 关键 技术 


使 用 支付 宝 进行 在 线 支付 ， 必 须 先 在 支付 宝 中 注册 一 个 账户 ， 然 后 下 载 
支付 宝 提供 的 接口 文件 ， 实 现 电子 商务 网 站 与 支付 宝 的 交互 。 

在 电子 商务 网 站 中 ,需要 嵌入 支付 宝 提供 的 几 个 文件 , 如 图 15.40 所 示 。 

在 支付 宝 提供 的 接口 文件 中 ， 提 供 了 完整 的 实例 程序 ， 只 要 依照 实例 程 
序 中 的 操作 方法 , 将 电子 商务 网 站 中 指定 的 数据 提交 到 支付 宝 提供 的 数组 参 
数 中， 支付 宝 即 会 通过 自己 定义 的 方法 将 数据 提交 到 指定 的 网 站 中 。 


图 设计 过 程 
(1) 单 击 确认 订购 信息 页 面 中 的 “选择 支付 方式 ”按钮 ， 进 入 如 图 15.41 所 示 的 支付 方式 选择 页 面 。 


slipay_eonfig, 支付 宝 提供 的 文件 


支付 宝 提供 的 文件 
支付 宝 提供 的 文件 
支付 宝 提供 的 文件 
支付 宝 提供 的 文件 


图 15.40 支付 宝 提供 的 文件 


页 两 刚刚 本 


return_url. php- 


和 执 TR9 扩 程 同 共产 吕 


注意， 提供 详 妇 联系 地 址 、 如 如 及 联系 电话 等 信息 


图 15.41 支付 方式 选择 页 面 


新 建 selectpaytype.php 文件 ， 包 含 网 页 的 头 文件 和 尾 文 件 ， 并 指定 模板 页 selectpaytype.phtml; 新 建 
selectpaytype.phtml 模板 页 ， 输 出 各 种 支付 方式 并 且 设 置 进入 指定 支付 方式 的 超 链 接 。 
(2) 单 击 支付 宝 支付 的 “支付 ” 超 链接 ， 将 跳 转 到 确认 支付 方式 页 面 ， 该 页 面 由 defpay.php 和 defpay.phtml 
组 成 。 
在 defpay.php 动态 页 中 , 根据 超 链接 传递 的 参数 值 确定 选择 的 支付 方式 和 类 型 ,并 且 将 存储 在 SESSION 变 
量 中 的 订单 信息 添加 到 数据 表 中 。 同 时 判断 如 果 选 择 的 是 支付 宝 在 线 支付 ($alertType ='2') ， 则 定义 向 支付 宝 
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网 站 中 提交 的 数据 ， 并 且 将 数据 赋 给 模板 变量 ， 在 模板 页 中 通过 form 表单 将 数据 提交 到 支付 宝 的 网 站 中 。 
defpay php 动态 页 的 关键 代码 如 下 : 


Ee once header. php'; 
$t=$_GET[t]: 
让 (St 一 'qyzh) { 
Spaytype = ' 企 业 账户 汇款 ': 
SalertType = 0'; 
jelseif ($t — ‘ztb) { 
Spaytype = 支付 宝 在 线 支付 ': 
SalertType = "2°; 
} elscif ($t =— ‘ghzxzf) { 
Spaytype = 工行 在 线 支付 '; 
SalertType ='3'; 


} 

/| 省略 了 部 分 代码 

if($alertType —'2') { 
Ssmarty->assign('‘orderid', $ er ‘TorderNo"D): 
Ssmarty->assign('ydType', EXPRESS"): 
S$smarty->assign('ydPrice', $_SESSION['recuserinfo']['recpay’]): 
S$smarty->assign('‘bookPrice’, $_SESSION[recuserinfo][bookprice]): 


} 
在 defpay.phtml 模板 页 中 ， 输 出 订单 的 确认 信息 ， 创 建 向 支付 宝 网 站 中 提交 数据 的 form 表单 ， 判 断 当 模板 
变量 $alertType 的 值 等 于 2 时 ， 完 成 向 支付 宝 网 站 中 提交 数据 的 操作 ， 其 关键 代码 如 下 : 


<form name="form_zfb" method="post" action="http://221.8.65.77/zfb/index.php" target="_blank"> 
<input type="hidden" name="ddno" value="{$orderid}"> 
<input type="hidden" name="ydType" value="{$ydType}"> 
<input type="hidden" name="ydPrice" value=" {util->moneyFormat p=$ydPrice}"> 
<input type="hidden" name="price" value=" {util->moneyFormat p=SbookPricej"> 
</form> 
<a {if $alertType —='0' } 
href="javascript:alert( 您 的 订购 信息 已 经 保存 ,请 到 指定 银行 汇款 !):" 
{elseif $alertType = '1'} 
href="javascript:alert(' 您 的 订购 信息 已 经 保存 ,请 到 邮局 邮 款 !");" 
{elseif SalertType = 2 
href="javascript:form_zfb.submitO:" 
{elscif SalerType — 3 
href="javascript:toicbe.submitO):" 
{请 
><img sre=" {util->baseUrl} /img/button_defpay.gif" border="0" /></a> 


国 秘笈 心 法 


心 法 领悟 611: 支付 宝 在 线 支付 。 
声明 : 这 里 讲解 的 是 通过 PHP 实现 电子 商务 网 站 与 支付 宝 进行 交互 的 方法 ， 其 中 涉及 的 支付 宝 提 供 的 参数 
和 设置 都 是 虚拟 的 ， 真 实 的 参数 将 在 实际 的 运作 中 由 支付 宝 提供 。 


: EE > 
图 实例 说 明 


在 选择 支付 方式 页 面 中 ， 单 击 工行 在 线 支付 的 “支付 ” 超 链 接 ， 将 跳 转 到 如 图 15.42 所 示 的 页 面 ， 输 出 本 
次 图 书 订购 的 订单 号 、 支 付 方式 和 需要 支付 的 总 金额 。 

如 果 单 击 图 15.42 中 的 “已 经 确认 订购 信息 按 选 择 支付 方式 支付 ”按钮 ， 将 跳 转 到 工行 在 线 支付 页 面 ， 如 
图 15.43 所 示 。 


PHP 开发 实例 大 全 (基础 卷 ) 


是 A 9 | - 
RTT iea A 了 aa Mg 下 = 


家 ma 刘 。 


图 15.42 支付 宝 在 线 支 付 图 15.43 工行 在 线 支付 


图 关键 技术 


工行 在 线 支 付 功 能 的 实现 主要 根据 工行 提供 的 在 线 支付 的 接口 ， 将 订单 中 的 数据 以 表单 的 形式 提交 到 工行 
指定 的 网 址 中 。 详 细 的 参数 设置 可 以 参考 工行 提供 的 文档 说 明 书 和 实例 程序 。 

在 实现 与 工行 接口 的 连接 之 前 ， 首 先 要 从 工行 提供 的 说 明 书 中 找到 两 个 文件 ， 开 发 API 接口 LIB\windows\ 
win32\infosecapi.dll (XP 系统 使 用 的 文件 ) 和 开发 API 接口 \ASP\ ICBCEBankUtil.dll， 并 将 其 复制 到 系统 文件 夹 
下 的 Windows\system32 下 ， 在 运行 命令 中 输入 regsvr32 ICBCEBankUtil.dll， 加 载 服 务 。 

通过 PHP 实现 网 站 与 工行 接口 交互 的 方法 如 下 : 

首先 , 通过 com 类 中 的 init0 方 法 对 订单 签名 数据 和 商城 的 公 钥 进 行 加 密 处 理 ， 并 且 将 指定 的 数据 以 表单 的 
形式 提交 到 工行 指定 的 页 面 中 ， 其 关键 代码 如 下 : 


Ssre="ICBC_PERBANK._ B2C1.0.0.0" $infomer["merid"].$infomer["meracct"] Sretumaddress "HS".Sddnumber $amount."0010".$nowtime."0"; 
Scom=new com('ICBCEBANKUTIL.B2CUItil); 
Sre=$com->init("e:\WINDOWS\user.crt","d: \user.crt","d: \user.key","00"): 


SE CS /订单 签名 数据 
Sre=$com->verifySignC(Ssrestrien($sre), Sssre strien(Sssre)); 
Scert=$com->getCert(1); // 商 城 证 书 公 钥 


完成 订单 签名 数据 和 商城 证 书 公 钥 的 加 密 处 理 后 , 将 商户 的 测试 证 书 存储 到 C:\Windows 目录 下 , 设置 商户 
的 私 钥 口令 为 00。 
然后 创建 form 表单 ， 将 指定 的 数据 提交 到 工行 指定 的 网 站 中 。 


图 设计 过 程 
工行 在 线 支付 的 操作 同样 由 defpay.php 和 defpay.phtml 两 个 文件 组 成 。 
(1) 在 defpay.php 动态 页 中 ， 判 断 如 果 选 择 的 是 工行 在 线 支付 ($alertType = '3') ， 则 定义 向 工行 在 线 支 


付 网 站 中 提交 的 数据 ， 并 且 将 数据 赋 给 模板 变量 ， 在 模板 页 中 通过 form 表单 将 数据 提交 到 工行 在 线 支付 的 网 站 
中 。 在 defpay.php 动态 页 中 ， 有 关 工 行 在 线 支 付 的 关键 代码 如 下 : 
<php 


require_once ‘header.php'; 

St=$_GET[Y]; 

让 (St 一 'qyzh) { 
$paytype = "企业 账 户 汇款 ': 
SalertType ="'0'; 

Yelseif ($t = ‘zfb) { 
S$paytype = 支付 宝 在 线 支付 ': 
SalertType ="2'; 

} elseif (St 一 ‘ghzxzf) { 
S$paytype =' 工 行 在 线 支付 
SalertType ="3'; 


} 
/省 略 了 部 分 代码 
if($alertType — 3) { 
Smerlnfo = $adminDB->executeSQL("select merid., meracct from tb_system where mark = 1". $connID): 
Smerid = $merInfo[OlP'merid": 
Smeracct = $merInfo[O]['imeracct ]: 
SmerURL = http://www.mrbooks.cn'; 
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Sorderid =$_SESSION['recuserinfo'][ orderNo"]: 

Snowtime = date("YmdHis"): 

Samount = str_replace(,, ". nunmiber._format($_SESSION['recuserinfo']['recpayall]. 2)); 
,S$ >” 


S$smarty->assign('sre', $sre): 


} 
(2) 在 defpay.phtml 模板 页 中 ， 输 出 订单 的 确认 信息 ， 创 建 向 工行 在 线 支付 网 站 中 提交 数据 的 form 表单 ， 
判断 当 模 板 变量 $alertType 的 值 等 于 3 时 ， 完成 向 工行 在 线 支付 网 站 二 提交 数据 的 操作 ， 其 关键 代码 如 下 : 


<form name="toicbe" method="post" action="http://221.8.65.75/icbc/toicbe.php" target=" 
<input name="orderid" type="hidden" value=" {$orderid}"/> 
<input name="amount" type="hidden" value="{$amount}"/> 
<input name="merID" type="hidden" value="{$merID}"/> 
<input name="merAcct" type="hidden" value=" {$merAcct}"/> 
<input name="merURL" type="hidden" value="{$merURL}"/> 
<input name="orderDate" type="hidden" value="{$orderDate}"/> 
<input name="sre" type="hidden" value="{$sre}"/> 
</form> 
<a {if $alertType — '0' } 
href="javascript:alert(' 您 的 订购 信息 已 经 保存 ,请 到 指定 银行 汇款 !)):" 
{elseif $alertType = "1'} 
href="javascript:alert(' 您 的 订购 信息 已 经 保存 ,请 到 邮局 邮 款 !):" 
{elseif $alertType = 21 
href="javascript:form_zfb.submit|:" 
{elseif $alertType = '3'} 
href="javascript:toicbe.submitO):" 
Wy 
><img sre=" {util->baseUrl} /img/button_defpay.gif” border="0" /></a> 


力 秘笈 心 法 
心 法 领悟 612: 工行 在 线 支付 。 
声明 : 这 里 讲解 的 只 是 通过 PHP 实现 电子 商务 网 站 与 工行 进行 交互 的 方法 ， 其 中 涉及 的 工行 提供 的 参数 和 


设置 都 是 虚拟 的 ， 真 实 的 参数 将 在 实际 的 运作 中 由 工行 提供 。 当 实际 需要 使 用 此 项 功能 时 需要 向 工行 申请 ， 工 
行 会 提供 相应 的 参数 以 及 一 些 详细 的 配置 方法 。 


力 实例 说 明 


网 站 后 台 的 主要 功能 是 对 网 站 信息 进行 管理 ， 所 以 只 有 网 站 管理 者 可 以 登录 ， 为 了 保证 网 站 的 安全 性 ， 后 
台 登 录 页 面 的 设计 和 业务 逻辑 的 实现 显得 非常 重要 。 下 面 介绍 明日 科技 图 书 网 后 台 首页 的 设计 和 功能 实现 ， 为 
了 提高 网 站 的 安全 性 ， 在 后 台 登 录 页 面 中 增加 了 验证 码 功能 ， 如 图 15.44 所 示 。 


15.8 ”后台 管 理 系统 登录 
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图 15.44 ”后 台 管理 系统 登录 


图 关键 技术 


在 后 台 管 理 系统 登录 功能 实现 过 程 中 ， 应 用 JavaScript 脚本 调用 xym.php 文件 完成 验证 码 的 输出 操作 。 在 
xym.php 文件 中 ， 应 用 文件 系统 函数 库 中 的 函数 将 指定 的 图 片 以 二 进 制 的 形式 输出 到 浏览 器 ， 其 代码 如 下 : 


<?php 

Snum=$_GET[num]; // 获 得 传递 的 数字 
Saddress="img/code/". $num." .gif'; // 获 取 对 应 图 片 地址 
Sfp=fopen($address,"r"); /打开 对 应 的 图 片 

echo fread($fp,filesize($address)); // 将 图 片 以 二 进 制 的 形式 输出 到 浏览 器 
felose($fp); /| 关闭 打开 的 图 片 

?> 


有 关 文 件 系统 函数 的 应 用 可 以 参考 本 书 第 4 章 的 内 容 ， 这 里 不 再 熬 述 。 
图 设计 过 程 
明日 科技 图 书 网 后 台 登 录 页 面 的 制作 过 程 主要 包括 登录 表单 的 设计 和 登录 信息 验证 。 


(1) 后 台 用 户 登录 表单 的 UI 是 通过 HTML 语言 的 <input> 标 签 实现 的 , 并 通过 JavaScript 实现 图 片 验证 码 ， 


admin-login.phtml 的 关键 代码 如 下 : 
<form name="form_login" method="post" action=" {util->baseUrl}/admin-login.php" onsubmit="retum chkinputadmin(this)"> 
<div style="width:300px; height:200px; text-align:left"> 
用 户 名 : <input type="text" name="anc" size="22" class="input" /><br /><br /> 
密码 : <input type="password" name="pwd" size="22" class="input" /><br /><br /> 
验证 码 ，<input type="text" name="xym" size="8" class="input" /><input type="hidden" value="" name="xym1"> 
‘<script language="javascript"> 
var numl=Math.round(Math.random()*10000000); 
var num=num]1 .toString().substr(0,4); 
document write("<img name=codeimg4 sre='xym.php?num="+num.substr(0.1)+">"); 
document.write("<img name=codeimgs sre='xym.php?num="+num.substr(1.1)+">"); 
document write("<img name=codeimg6 sre=xym.php?num="+num.substr(2.1)+">"); 
document write("<img name=codeimg7 sre='xym.php?num="+num.substr(3.1)+">"); 
form_login xyml .value=num; 
function code 1(){ldelim} 
var num1=Math.round(Math.random()*10000000); 
var num=numl .toString().substr(0,4); 
document.codeimg4.sre="xym php?num="+num.substr(0,1); 
document.codeimg$.sre="xym. php?num="+nunm.substr(1,1); 
document.codeimg6.sre="xym.php?num="+nunm.substr(2,1); 
document.codeimg7.sre="xym.php?num="+num.substr(3,1); 
form login.xyml .value=num:; 
{rdelim} 
</script> 
<a hre 仁 "javascript:code_10" class="al"> 看 不 清 </a> 
<input type="submit" value=" 登 录 " 广 &nbsp:&nbsp:<input type="reset" valuc=" 重 置 " /> 
</div> 
</form> 
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(2) 在 admin-login.php 文件 中 完成 对 用 户 名 和 密码 的 验证 ， 如 果 用 户 名 和 密码 不 正确 ， 则 提示 登录 失败 ; 
否则 将 登录 用 户 名 存储 到 SESSION 变量 中 ， 并 且 跳 转 到 后 台 管 理 系统 的 admin-index.php 页 面 ， 其 代码 如 下 : 


require_once "lzh ine.php’; 


让 人 Gisset($_ POST[anc]) && $ POST[anc] =") { // 判 断 用 户 是 否 提交 了 表单 
if($adminDB->executeSQL("select id, useme from tb user where usemc=" .$ POSTJ'anc1." and pwd=" . mdS(trim($ POSTfpwdT). "and 
usertype=1", $connID)) { /根据 用 户 昵称 和 密码 查询 管理 员 
if(isset($_SESSION['ane'])) { 1/ 如果 查询 到 则 说 明 登 录 成 功 ， 这 时 将 管理 员 昵 称 保存 到 SESSION 中 


unset($_SESSIONT'anc ]): 


} 

$_SESSION['ane'] =$_POST['ane']: 

echo "<script>window.location.href=" . Sutil->baseUrl0 . "/admin-index.php':</script>"; 。 ”// 重 定向 到 后 台 首 页 
}else { 

echo "<script>alert(' 登 录 失 败 ! ");</script>"; // 给 出 登录 失败 提示 
} 


} 
S$smarty->display('admin-login.phtml ); 
$connDB->closeConnID(); // 关 闭 数据 库 连接 


图 秘笈 心 法 


心 法 领悟 613: 防止 后 台 管理 系统 中 的 程序 被 非法 访问 。 

防止 后 台 管理 系统 中 的 程序 被 非法 访问 ， 关 键 就 在 于 登录 成 功 后 创建 的 9 SESSION[anc'] 变 量 ， 通 过 这 个 变 
量 值 来 确保 后 台 管 理 员 的 特殊 权限 。 在 执行 后 台 管理 系统 中 的 操作 时 , 都 会 首先 判断 $_SESSION['anc'] 变 量 的 值 ， 
如 果 为 空 则 说 明 是 非法 访问 ， 将 给 出 提示 信息 并 跳 转 到 后 台 管理 系统 的 登录 页 面 。 


实例 614 


实例 说 明 


明日 科技 图 书 网 站 的 后 台 管 理 员 登 录 成 功 后 ， 将 进入 后 台 管 理 系统 的 主页 ， 主 页 通过 frame 框架 设计 ， 展 
示 出 后 台 管 理 系统 中 的 所 有 功能 ， 其 页 面 效果 如 图 15.45 所 示 。 


15.45 后台 管理 系统 主页 


图 关键 技术 


在 后 台 管 理 系统 的 主页 中 ， 应 用 frame 框架 将 后 台 管理 系统 主页 分 为 两 部 分 : 左 侧 的 导航 页 面 和 右 侧 的 中 
心 内 容 显示 页 面 。frame 框架 的 代码 如 下 : 
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<noscript><iframe sre="* html"></iframe></noseript> 
<frameset cols="182. +"> 

<frame sre=" {util->baseUrl}/admin-left php" name="leftwindow"> 
<frame sre=" {util->baseUrl}/admin-main php" name="mainwindow"> 
</frameset><noframes></noframes> 


图 设计 过 程 
后 台 管理 系统 的 主页 主要 由 两 个 文件 组 成 : admin-index.php 和 admin-index.phtml。 
(1) 在 admin-index.php 文件 中 ， 首 先 包 含 系统 的 配置 文件 。 然 后 判断 当前 用 户 是 否 具 有 管理 员 的 权限 ， 


如 果 不 具 备 则 给 出 “禁止 非法 登录 ”的 提示 信息 ， 并 跳 转 到 网 站 的 首页 。 最 后 指定 后 台 管理 系统 主页 的 模板 页 
admin-index.phtml， 其 代码 如 下 : 


require_once ‘zh.inc.php'; 
ifl!lisset($_SESSION['anc']) || $_SESSION['anc] =— "){ 
echo "<script>alert( 禁 止 非法 登录 ! ");window.location href=".$util->baseUrl0."/index.html';</script>"; 
exit(); 
} 
S$smarty->display('admin-index.phtml"); 
(2) 新 建 admin-index.phtml 模板 页 ， 应 用 frame 框架 完成 后 台 管理 系统 主页 的 设计 ， 其 代码 如 下 : 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 明 日 网 上 书店 管理 中 心 </title> 
<link rel="stylesheet" type="text/css" href="css/style.css"> 
</head> 
<noscript><iframe sre="*.html"></iframe></noscript> 
<frameset cols="182, *"> 
<frame src=" {util->baseUrl}/admin-left.php" name="leftwindow"> 
<frame sre=" {util->baseUrl}/admin-main.php" name="mainwindow"> 
</frameset><noframes></noframes> 
(3) 左 侧 导 航 页 面 由 一 个 动态 PHP 文件 admin-left.php 和 一 个 模板 页 admin-left.phtml 组 成 。 在 admin-left. 
php 文件 中 包含 系统 配置 文件 ， 指 定 模 板 页 。 
在 模板 页 admin-left.phtml 中 ， 应 用 jQuery 技术 设计 后 台 管理 系统 的 导航 菜单 ， 通 过 超 链 接 中 的 target 属性 


指定 链接 文件 在 mainwindow 框架 中 输出 ， 其 关键 代码 如 下 : 
<head> 


<title> 明 日 网 上 书店 管理 中 心 - 左 侧 导 航 </title> 

<meta http-equiv="Content-Type" content="text/html; charset="gbk" /> 

<link rel="stylesheet" type="text/css" href=" {util->baseUrl}/css/style.css" /> 
</head> 
<script sre=" {util->baseUrl}/js/jquery.js"></script> 
<script sre=" {util->baseUrl} /js/adminleft.js"></script> 
<div style="width:170px: border:1px solid #FFFFFF"> 

<div id="adminsystembutton" style="width:170px: height:34px; «background-color:#4995A8; cursor:hand: background:url( {util->baseUrl}/img/ 
button xtgl.gif)"> 

</div> 

<div id="adminsystem" style="width:100%px:; height:25px: padding-top:Spx: font-size:13px: background-color:#A3C7D0: line-height:20px; 
display:none"> 

<li style="display:inline; width:100%; text-align:left; padding-left:30px">|-&nbsp:<a href=" {util->baseUrl}/admin-default.php" class="al”" 
target="mainwindow"> 系 统 信息 设置 </a></li> 

<li style="display:inline: width:10096: text-align:left; padding-left:30px">|-&nbsp:<a href=" {util->baseUrl}/admin-changepwd.php" class="al” 
target="mainwindow"> 更 改 管理 员 密 码 </a></li> 

<li style="display:inline: width:100%: text-align:left: padding-left:30px">|-&nbsp:<a href=" {util->baseUrl}/admin-logout.php" class="al" 
target=”parent"> 注 销 退 出 </a></li> 

</div> 
</div> 


(4) 右 侧 页 面 默认 展示 由 admin-main.php 和 admin-main.phtml 文件 组 成 的 内 容 。 在 admin-main.php 文件 
中 ， 首 先 包含 后 台 管 理 系统 的 头 文件 admin-header.php， 然 后 指定 模板 页 admin-main.phtml， 最 后 包含 尾 文件 
admin-footer.php。 在 admin-main.phtml 模板 页 中 ， 输 出 后 台 管 理 系统 的 系统 信息 。 
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心 法 领悟 614: 超 链接 中 target 属性 的 应 用 。 

超 链接 中 target 属性 包含 5 个 属性 值 : _blank 在 新 窗口 中 打开 超 链 接 文件 ，_parent 将 链接 文件 载 入 含有 链 
接 框 架 的 父 框架 或 窗口 中 , 如 果 含 有 该 链接 的 框架 不 是 嵌 套 的 , 则 在 浏览 器 全 屏 窗口 中 载 入 链接 的 文件 , 与 _self 
参数 相同 ，_self 在 同一 框架 或 窗口 中 打开 链接 的 文件 ， 此 参数 为 默认 值 ， 通 常 不 必 指 定 ，_top 在 当前 的 整个 浏 
览 器 窗口 中 打开 链接 的 文件 ， 因 此 会 删除 所 有 框架 ，name 在 指定 的 窗口 或 框架 中 打开 网 页 。 

在 本 实例 的 admin-left.phtml 模板 页 中 ， 通 过 超 链接 的 target 属性 指定 mainwindow 框架 ， 在 该 框架 中 打开 
链接 的 网 页 。 


15.9 系统 管理 


系统 管理 主要 用 于 对 系统 公用 信息 进行 设置 及 对 管理 员 密码 进行 更 改 , 通过 该 模块 可 以 提高 系统 的 可 维护 性 。 


力 实例 说 明 


明日 科技 图 书 网 的 系统 信息 设置 主要 用 于 设置 商城 DD、 企业 账号 、 企 业 版 权 、 联 系 方式 和 程序 文件 的 保存 
路 径 等 信息 ， 系 统 信息 设置 的 页 面 如 图 15.46 所 示 。 
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15.46 系统 信息 设置 页 面 


图 关键 技术 


在 本 实例 中 ， 关 键 之 处 不 在 于 系统 信息 设置 功能 的 实现 方法 ， 更 重要 的 是 它 的 操作 。 在 进行 系统 信息 设置 
时 ， 必 须 设置 最 后 3 项 内 容 ， 它 们 指定 的 是 系统 中 图 片 、 广 告 和 试 读 文 件 的 下 载 地 址 ， 如 果 设 置 的 路 径 不 正确 ， 
那么 这 3 项 内 容 将 不 能 正确 输出 。 

笔者 在 编写 此 实例 时 ， 将 其 路 径 设置 为 http://127.0.0.1/MR/15/005/， 这 是 在 本 地 服务 器 运行 的 路 径 ， 如 果 将 
这 个 程序 上 传 到 互联 网 的 服务 器 中 ， 就 必须 修改 这 个 路 径 ， 否 则 将 找 不 到 指定 的 图 片 和 文件 。 
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图 设计 过 程 


系统 信息 设置 功能 由 admin-default.php 和 admin-default.phtml 两 个 文件 组 成 。 

(1) 在 admin-default.php 文件 中 ， 完 成 数据 库 中 存储 的 系统 信息 的 输出 和 更 新 两 项 操作 。 首 先 包 含 后 台 管 
理 系统 的 头 文件 ， 然 后 判断 form 表单 中 提交 的 merid 值 是 否 为 空 ， 如 果 不 为 室 ， 则 应 用 数据 库 管理 类 的 
executeSQL() 方 法 执行 更 新 语句 ， 更 新 数据 库 中 存储 的 系统 信息 。 最 后 应 用 数据 库 管 理 类 的 executeSQL( 方 法 执 
行 查询 操作 ， 查 询 数据 库 中 存储 的 系统 信息 并 将 其 存储 到 模板 变量 中 ， 其 代码 如 下 : 

<php 


require_once 'admin-header.php'; // 包 含 网 站 头 文件 
if(isset($_POST['merid"]) && $_POST['merid] = ") { // 判 断 表单 提交 的 数据 是 否 为 空 

if (1 $adminDB->executeSQL("update tb system set merid . $ POSTI'merid] . ", meracet=" . $ POST['meracet] . ™, readurl=" , 
$_POST[readurd'] . ", bookimgudi=" . $_POST[bookimgurl] . ", ggur-=" . $_POST[ ggud'] . ", bq=" . $_POST[bq] . ", address=" . 
S POSTTaddress]. "tcl=".$ POSTTtel] . ", ez" . $_POST[ez] . ™, email=" . $_POST[ email] . ", icp=" . $_POST[icp] . ", qq=" . $_POST['aq] . 

™ where mark=1", $connID)) { 
echo "<script>alert(' 系 统 信息 设 置 失败 ! ");</script>"; 
} else{ 
echo "<script>alert( 系 统 信息 设置 成 功 ! ");</script>"; 


} 
Ssystem = $adminDB->exccuteSQL("select id, merid, meracct readurl, bookimgurl, ggurl, bq, address, tcl cz email, icp, qq from tb_system where 
mark=1", $connID); 


Ssmarty->assign('system', $system); // 将 查询 结果 赋 给 模板 变量 
$smarty->display(admin-defaultphtml)); /指定 模板 页 
require_once ‘admin-footer.php'; // 包 含 网 站 尾 文件 


(2) 新 建 admin-default.phtml 模板 页 ， 创 建 form 表单 ， 提 交 需 要 更 新 的 系统 信息 ， 并 且 将 模板 变量 中 传递 
的 系统 信息 作为 表单 元 素 的 默认 值 。 


图 秘 稚 心 ; 
心 法 领悟 615: 通过 JavaScript 脚本 中 的 chkinputsysteminfo0 方 法 验证 表单 元 素 值 。 


在 本 实例 的 admin-default.phtml 模板 页 中 ， 调 用 js/adminfunjs 文件 中 的 chkinputsysteminfo() 方 法 对 系统 信 
息 设置 表单 中 提交 的 数据 进行 验证 。 


力 实例 说 明 


为 了 便于 网 站 管理 者 对 网 站 进行 管理 提高 网 站 的 安全 性 ， 在 系统 管理 模块 增加 管理 员 密 码 修改 功能 ， 
如 图 15.47 所 示 。 


趣味 指数 : 二 从 让 从 | 


em 
PE: 
ESILLLL 


| 下 下 
图 15.47 管理 员 密码 修改 


图 关键 技术 


更 改 管理 员 密码 的 原理 : 用 户 在 上 述 表 单 中 输入 原 密码 和 新 设 定 的 密码 ， 单 击 “ 更 改 ” 按 钮 将 表单 中 的 信 
息 提交 到 admin-changepwd.php 文件 中 对 密码 进行 更 改 , 在 该 文件 中 ,首先 判断 用 户 输入 的 原 密码 是 否 正 确 ， 如 
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果 正 确 则 使 用 数据 库 管理 类 的 executeSQL0O 方 法 执行 update 语句 对 管理 员 密码 进行 更 改 ， 反 之 则 给 出 原 密码 错 
误 的 提示 信息 。 


四 设计 过 程 


后 台 管理 员 密 码 修改 功能 由 admin-changepwd.phtml 和 admin-changepwd.php 两 个 文件 组 成 。 
(1) 新 建 admin-changepwd.phtml 模板 页 ， 创 建 form 表单 ， 将 要 重新 设置 的 密码 提交 到 admin- 
changepwd.php 文件 中 。 
(2) 新 建 admin-changepwd.php 文件 ， 完 成 密码 更 新 操作 。 首 先 ， 验 证 表单 中 提交 的 原始 密码 是 否 正确 ， 
如 果 不 正确 则 给 出 提示 信息 ; 如 果 正 确 ， 执 行 密码 的 更 新 操作 ， 其 代码 如 下 : 


<php 
require_once 'admin-headerphp' // 包 含 网 站 头 文件 
if(isset($_POST['oldpwd']) && $_ POST['oldpwd] !=") { 1/ 判断 用 户 提交 的 原始 密码 是 否 存在 
if(! $adminDB->executeSQL("select id, useme from tb user where usemc=" .$ SESSIONT'anc1." and pwd=" .mds($ POST'oldpwdTD ."", 
S$connID)) { /验证 用 户 提交 的 原始 密码 是 否 正确 


echo "<script>alert( 原 密码 输入 有 误 ! ));</script>"; 
j else{ 

if ($adminDB->executeSQL("update tb_user set pwd=" .mds($_POST[pwdl]) .", truepwd=" .$ POST[pwdl]."where userne=" . 

$_SESSION['anc] . "",$connID)) { /如 果 原 始 密码 正确 ， 则 执行 密码 更 新 操作 
echo "<script>alert(' 密 码 更 改 成 功 ! ):</script>": 
} else{ 
echo "<script>alert(' 密 码 更 改 失败 ! );</script>"; 

} 

， 


} 
$smarty->display(admin-changepwd.phtml); // 指 定 模板 页 


require_once ‘admin-footer. php'; // 包 含 网 站 尾 文件 
图 秘笈 心 ; 


心 法 领悟 616: 通过 chkChangePwd () 方 法 验证 表单 提交 的 信息 。 
在 本 实例 的 admin-changepwd.phtml 模板 页 中 ， 调 用 js/adminfon.js 文件 中 的 chkChangePwd 0 方法 验证 表单 
中 提交 的 新 密码 与 确认 密码 是 否 相 同 ， 并 验证 提交 的 密码 长 度 是 否 大 于 6 个 字 节 。 


15.10 图 书 类 别管 理 


为 了 便于 用 户 选 购 和 查看 图 书信 息 ， 在 明日 科技 图 书 网 的 图 书展 示 模 块 实现 按 图 书 分 类 展示 和 按 出 版 社 分 
类 展示 功能 。 本 节 将 介绍 如 何在 网 站 后 台 对 图 书 类 别 进行 管理 。 


实例 617 ; | 本 和 食 窒 食 个 


看 实例 说 明 

在 明日 科技 图 书 网 中 ， 为 提高 图 书 分 类 层次 ， 在 图 书 分 类 
展示 模块 首先 要 求 用 户 选择 图 书 大 类 ， 然 后 再 选择 图 书 小 类 来 
展示 图 书信 息 列 表 。 图 书 大 类 管理 主要 包括 对 类 别 的 添加 、 修 
改 和 删除 操作 。 图 书 大 类 管理 中 浏览 图 书 大 类 信息 的 页 面 效 果 
如 图 15.48 所 示 。 图 15.48 浏览 图 书 大 类 信息 
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国 关键 技术 


在 图 书 大 类 管理 中 ， 应 用 最 多 的 就 是 数据 库 管 理 类 中 的 executeSQL0 方 法 ， 通 过 该 方法 执行 SQL 语句 ， 完 


成 数据 库 中 数据 的 添加 、 更 新 、 查 询 和 删除 操作 ， 这 也 是 所 有 后 台 管 理 系 统 中 最 常用 的 管理 手段 。 
图 设计 过 程 


(1) 添加 图 书 大 类 信息 由 admin-bigtype.phtml 和 admin-bigtype.php 两 个 文件 组 成 。 在 admin-bigtype.phtml 


模板 页 中 , 创建 form 表单 ， 将 图 书 大 类 的 名 称 提 交 到 admin-bigtype.php 文件 中 进行 处 理 ， 并 且 创建 添加 图 书 大 
类 信息 和 浏览 图 书 大 类 信息 的 按钮 ， 其 关键 代码 如 下 : 


<div style="width:9896: height:25px: text-align:left"> 

<input type="button" value=" 添 加 图 书 大 类 信息 ” onclick="window -location href-'futil->bascUrlj/admin-bigtypephp" />&nbsp:&nbsp; 
<input type="button" value=" 浏 览 图 书 大 类 信息 " onclick="window .location hre 人 ="{util->baseUrl}/admin-listbigtype.php"/> 

<ldiv> 


在 admin-bigtype.php 文件 中 , 获取 表单 中 提交 的 图 书 大 类 名 称 , 首先 , 应 用 数据 库 管理 类 中 的 executeSQLO 


方法 执行 查询 操作 ， 判 断 在 数据 库 中 是 否 存在 该 类 别 ， 如 果 不 存在 ， 则 应 用 数据 库 管理 类 中 的 executeSQL0O 方 
法 执行 添加 操作 ， 完 成 图 书 大 类 的 添加 操作 ， 其 代码 如 下 : 


?php 
require_once ‘admin-header.php’; // 包 含 网 站 头 文件 ， 在 头 文件 中 包含 了 配置 文件 
if(isset($_POST['typename']) && $_POST['typename’] (=") { // 判 断 类 别名 称 是 否 为 空 
if(! $adminDB->executeSQL("select id, typename from tb_bigtype where typename=" . trim($_POST['typename’]) . "", et 
if(! $adminDB->executeSQL("insert into tb_bigtype(typename. addtime) values(" . trim($_POST[typename]) . ™, " . date('Y-m-d H:i:s') . ")", 
SconnID)) { 
echo "<scriipt>alert( 类 别 添加 失败 ! );</script>"; 
} else{ 
echo "<script>alert( 类 别 添加 成 功 ! );</script>"; 
} 
} else{ 
echo "<script>alert(' 该 类 别 已 经 添加 ! ;</script>"; 
} 
Ssmarty->display('admin-bigtype.phtml"); 1/ 指定 模板 页 
require_once ‘admin-footer.php'; // 包 含 尾 文件 


(2) 浏 览 图 书 大 类 信息 由 admin-listbigtype.php 和 admin-listbigtype.phtml 文件 组 成 。 在 admin-listbigtype.php 


定义 图 书 大 类 信息 的 删除 、 更 新 和 查询 3 个 方法 ， 完 成 对 图 书 大 类 信息 的 操作 ， 其 代码 如 下 : 
< 

i ‘admin-header.php'; // 包 含 头 文件 

if(isset($_GET[f]) && $_GET[f] = 'del) { // 判 断 是 否 执 行 删除 操作 


if(! $adminDB->executeSQL("delete from tb_bigtype where id=" . $_GET[id] . "", $connID)) { 
echo "<script>alert( 类 别 删除 失败 ! :</script>"; 
} 


| 

SisShow ='F'; 

if((isset($_GET['?]) && $_GET[?] — ‘edit) || (isset($_POST[?)) && $_POST[?f] — ‘edit)) { 1/ 判 断 是 否 执行 更 新 操作 
让 (isset($_ POST[f]) && $_POST[f] = 'edit) { // 判 断 是 否 执 行 更 新 操作 


证 (! $adminDB->executeSQL("update tb_bigtype set typename=" . $_POST['typename] ." where id=" .$ POST[id] ."", $connID)) { 
echo "<script>alert( 类 别 更 改 失败 ! ");</seript>"; 

}else{ 
echo "<script>alert( 类 别 更 改 成 功 ! ");</script>": 

} 


让 (isset($_GET[id]){ // 获 取 数据 的 ID 
$id=$_GET[id]: 
j else{ 
$id=$ POST[id]: 
} 
SisShow = T'; 
Sbigtype = $adminDB->executeSQL("select id, typename from tb_bigtype where id=" . $id ."", $connID); 。 ” // 执 行 数据 的 查询 操作 
Ssmarty->assign('bigtype'. Sbigtype): // 将 要 重新 编辑 的 信息 赋 给 模板 变量 
} 


Ssmarty->assign('isShow', $isShow): 
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Sbigtypes = $adminDB->executeSQL("select id, typename. addtime from tb_bigtype order by addtime ". SconnID): /循环 读 取 数 据 
S$smarty->assign('bigtypes', $bigtypes): /将 查询 结果 赋 给 模板 变量 
$smarty->display(admin-listbigtype phtmly: /指定 模板 页 

require_once 'admin-footerphp': 


国 秘笈 心 法 


心 法 领悟 617: section 语句 的 应 用 。 
在 输出 图 书 大 类 信息 时 ， 应 用 的 是 Smarty 模板 中 的 section 语句 ， 并 且 调 用 注册 模板 对 象 中 的 unHtml( 方 
法 对 输出 的 数据 进行 格式 化 的 操作 。 


实例 618 


力 实例 说 明 EE a 


ET 


在 图 书 大 类 管理 的 基础 上 为 了 更 加 精确 地 定位 图 书 ， 方 便 读 
者 查找 ， 明 日 科技 图 书 网 的 图 书展 示 模块 又 精确 到 小 类 ， 例 如 ， Var 区 一 
程序 类 图 书 又 精确 到 具体 的 开发 语言 。 在 图 书 小 类 中 添加 小 类 名 一 岂 
称 和 选择 所 属 大 类 的 运行 效果 如 图 15.49 所 示 。 Ea 
关键 技术 图 15.49 图 书 小 类 录入 表单 


在 图 书 小 类 管理 中 ， 应 用 最 多 的 还 是 数据 库 管理 类 中 的 executeSQL() 方 法 ， 由 其 完成 图 书 小 类 数据 的 添加 、 
更 新 、 查 询 和 删除 操作 。 同 时 还 应 用 Smarty 模板 的 html_options 标签 将 所 有 大 类 名 称 在 下 拉 列 表 中 输出 ， 其 代 
码 如 下 : 

<select name="bigtypeid"> 

<option value="">- 请 选择 -</option> 

{html_options options = $arrayBtypeOption} 

</select> 
看 设计 过 程 

(1) 用 户 首先 在 小 类 名 称 文本 框 中 输入 小 类 名 称 ， 然 后 选择 该 小 类 所 属 大 类 ， 单 击 “ 添 加 ”按钮 ， 表 单 内 
容 将 被 提交 到 admin-smalltype.php 文件 中 进行 保存 ，admin-smalltype.php 的 代码 如 下 : 

S$btypes = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime", $connID): /查询 大 类 信息 

for ($i= 0; Si< count($btypes); $i ++) { // 将 大 类 信息 保存 到 数组 中 

S$arrayBtypeOption[$btypes[Sil[id11 = $btypes[S$ill'typename': 

S$smarty->assign('arrayBtypeOption', $arrayBtypeOption): 

证 (isset($_POST[typename']) && $_POST['typename'] (=") { 


if(! $adminDB->executeSQL("select id, typename from tb smalltype where typename=" . trim($ POST'typename"]) . "", $connID)) { 
if(! $adminDB->executeSQL("insert into tb_smalltype(typename. bigtypeid, addtime) values(" . trim($_POST['typename’]) . ", " . 


trim($_POST[bigtypeid]) . "," . date(Y-m-d H:i:s) . ")", $connID)) { /| 执行 添加 操作 
echo "<scriipt>alert( 类 别 添加 失败 ! ”);</seript>"; 
}else{ 


p echo "<script>alert( 类 别 添加 成 功 ! "):</seript>"; 
. 有 "<script>alert(' 该 类 别 已 经 添加 ! ");</script>"; 
} 
上 述 代码 首先 查询 所 有 图 书 大 类 名 称 和 ID 并 保存 到 二 维 数组 中 ， 然 后 通过 Smarty 模板 的 html_options 标 
签 将 所 有 大 类 名 称 在 下 拉 列 表 框 中 输出 ， 然 后 使 用 函数 issetO 判 断 是 否 提交 表单 ， 如 果 是 ， 则 使 用 数据 库 管理 
类 的 executeSQL0O 方 法 保存 小 类 信息 。 


885 
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(2) 在 图 书 小 类 展示 模块 中 ， 主 要 显示 出 图 书 小 类 


的 名 称 、 所 属 大 类 和 小 类 添加 时 间 , 其 运行 效果 如 图 15.50 > Ee 本 | 茹 向 
所 示 。 一 下 5 E23 
单 击 图 书 小 类 信息 列表 页 中 的 编辑 按钮 ,将 出 现 小 类 编 一 ey 
辑 表单 , 用 户 更 改 小 类 信息 并 提交 表单 后 , 表单 内 容 将 被 提 国 4539) 国 汕 小 尖 相 四 列 家 
交 到 admin-listsmalltype.php 文件 中 实现 对 图 书 小 类 信息 的 更 改 ， 其 关键 代码 如 下 : 
S$isShow = 'F'; 
if((isset($_GET[?]) && $_GET[?] = 'edit) || Gisset($_ POST[f]) && $_POST[f] = 'edit)) { 
Sbtypes = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime", $connID); ” // 获 得 大 类 信息 
for ($i= 0; $i< count($btypes): $i++) { /将 大 类 信息 保存 到 数组 中 
SarayBtypeOption[Sbtypes[Sil[id]] 一 Sbtgypes[$i][ gpcname]; 
$smarty->assign('arrayBtypeOption', $arrayBtypeOption): 
让 (isset($_POST[f]) && $ POST[?f] = 'edit) { // 进 行 编辑 操作 
if(! enn et ‘update tb_smalltype set typename=" . $_POST['typename'] . ", bigtypeid=" . $_POST['bigtypeid'] . " where 
".$ POST[id] ." 


echo > ;</script>": 
} else{ 
echo "<script>alert( 类 别 更 改 成 功 ! :</script>"; 
} 
} 
if (isset($_GET['id"))) { 
$id=$ GETTid1; 
} else{ 
$id=$ POST[id]; 
SisShow = "T'; 
$smalltype = $adminDB->executeSQL("select id typename, bigtypeid from tb_smalltype where id=" . $id . "", $connID); /查询 小 类 信息 
S$smarty->assign('smalltype’, $smalltype); 


} 

上 述 代码 首先 判断 S_GET[f] 数 组 元 素 是 否 已 经 设置 ， 如 果 是 ， 则 说 明 用 户 单 击 编辑 按钮 ， 这 时 查询 出 所 有 
大 类 名 称 ， 并 使 当前 所 编辑 小 类 的 大 类 名 称 处 于 选中 状态 ， 然 后 判断 是 否 设置 8 POST[f] 数 组 元 素 的 值 ， 如 果 
是 ， 则 说 明 已 经 提交 小 类 信息 更 改 表单 ， 此 时 通过 数据 库 管理 类 的 executeSQL0 方 法 更 改 小 类 信息 。 

(3) 如 果 管 理 员 单 击 小 类 信息 列表 页 中 的 删除 按钮 ， 则 首先 弹出 一 个 提示 框 提 示 用 户 是 否 确认 删除 ， 如 果 


是 ， 则 通过 数据 库 管理 类 的 executeSQL() 方 法 执行 delete 语句 删除 指定 的 小 类 信息 ， 其 代码 如 下 : 
if (isset($_GET[f]) && $_GET[?] = 'del) { 
证 (! $adminDB->executeSQL("delete fiom tb_smalltype where id=" . $_GET[id] . ww, $connID)) { 
ccho "<script>alert( 类 别 删 除 失败 ! <seript>": /执行 删除 
} 
} 


力 秘笈 心 法 


心 法 领悟 618: 应 用 issetO 函 数 判断 指定 的 变量 是 否 存在 。 
issetO 函 数 检查 变量 是 否 被 设置 ， 如 果 设 置 则 返回 TRUE， 和 否则 返回 FALSE。 由 于 这 是 一 个 语言 结构 而 非 函 
数 ， 因 此 它 无 法 被 “变量 函数 ”调用 ， 其 语法 如 下 : 


bool isset (mixed var [, mixed var[ ..]]) 


参数 var 为 被 检查 的 变量 ， 可 以 有 多 个 。 


高 级 | 
实例 619 趣味 指数 : od 
图 实例 说 明 


图 书 不 但 可 以 按 内 容 划 分 ， 还 可 以 按 其 所 属 出 版 社 进行 分 类 ， 这 样 可 以 更 加 方便 地 引导 读者 选 购 自己 信赖 
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的 出 版 社 所 出 版 的 图 书 。 为 使 出 版 社 分 类 更 加 形象 、 易 于 识别 , 在 出 版 社 分 类 中 增加 了 出 版 社 的 Logo 图 片 信息 ， 
浏览 出 版 社 类 别 信息 的 页 面 效果 如 图 15.51 所 示 。 


锥 tn 出 散 社 寺 别 信息 齐 蜗 出 其 社 潜 列 信 息 
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| 


15.51 浏览 出 版 社 类 别 信息 


图 关键 技术 


在 出 版 社 分 类 管理 中 ， 关 键 是 出 版 社 Logo 图 标 上 传 的 实现 方法 ， 其 上 传 应 用 的 是 move_uploaded file0 函 数 。 
(1) 在 执行 上 传 之 前 ， 应 用 is_dir0 函 数 判 断 指定 的 文件 夹 是 否 存在 ， 如 果 不 存 在 则 应 用 mkdir0 函 数 创建 
一 个 新 文件 夹 。 
(2) 应 用 $_FILES[] 全 局 数组 获取 上 传 图 片 的 原始 名 称 。 
(3) 定义 上 传 文件 在 服务 器 文件 夹 下 的 存储 名 称 ， 应 用 date0 函 数 获 取 时 间 戳 ， 应 用 mt_rand0 函 数 定义 随 
机 数 ， 通 过 substr0 函 数 获 取 原 始 文 件 的 后 缀 名 称 ， 从 而 组 成 新 的 文件 名 称 。 
(4) 定义 上 传 文件 在 服务 器 中 的 存储 路 径 。 
(5) 应 用 move_uploaded_file0 函 数 执行 文件 上 传 操作 。 
上 述 函 数 的 详细 讲解 可 以 参考 本 书 第 4 章 的 内 容 ， 这 里 不 再 歼 述 。 


力 设计 过 程 
(1) 网 站 管理 者 在 添加 出 版 社 名 称 并 选择 出 版 社 Logo 图 片 后 ， 单 击 “添加 ”按钮 即 可 将 出 版 社 类 别 信息 
提交 到 admin-pub.php 文件 中 进行 处 理 ， 其 代码 如 下 : 


让 (isset($_POST[pubname]) && $_ POST[pubname] !=") { /如 果 提 交 了 表单 
/判断 该 出 版 社 是 否 已 经 添加 
让 (! $adminDB->executeSQL("select id, pubname from tb_pub where pubname=" .trim($_POST[pubname]) . "",S$connID)) { 
if(isset($_FILES["pubimg"]["name"]) && $_FILES["pubimg"]["name"] (= "") { // 上 传 出 版 社 Logo 


$dir ="./upfiles/bookimg"; 
if(!is dir($diD) { 
mkdir($dir): 


} 
Supfilename = $_FILES["pubimg"]["name"]; 


Sfilename = date("YmdHis") . mt rand(1000. 9999) . substr($upfilename. strpos($upfilename. "."), strlen($upfilename) - 
strpos($upfilename, ".")): 站 是 外 设 社 信 容 演 人 

Saddress = $dir . "/". $filename: 

@move_uploaded_file($_FILES["pubimg"]["tmp_name"], $address): 1/ 执行 上 传 操作 


} else{ 
Sfilename =""; 


证 (! $adminDB->executeSQL("insert into tb pub(pubname. pubimg, addtime) values(™ . trim($ POSTf'pubname"]) . ™, ". $filename . ™, ™ . 
date(Y-m-d H:i's) . ")", $connID)) { /保存 出 版 社 类 别 信息 
echo "<script>alert( 出 版 社 类 别 添加 失败 ! ):</script>"; 
}else{ 
echo "<script>alert(' 出 版 社 类 别 添加 成 功 ! ):</script>"; 
} 
}else{ 
echo "<script>alert( 该 出 版 社 类 别 已 经 添加 ! ):</script>": 
} 
} 
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上 述 代码 使 用 函数 move_uploaded_file() 上 传 出 版 社 Logo， 成 功 上 传 后 ， 使 用 数据 库 管 理 类 的 executeSQLO 
方法 执行 insert 语句 保存 出 版 社 类 别 信息 。 
(2) 出 版 社 类 别 信息 列表 页 显示 出 版 社 Logo、 出 版 社 名 称 和 类 别 添加 时 间 。 管 理 员 单 击 出 版 社 类 别 列表 
中 的 “编辑 ” 超 链接 , 将 出 现 出 版 社 类 别 更 改 表 单 , 对 出 版 社 信息 进行 编辑 , 将 表单 内 容 提 交 到 admin-listpub.php 
文件 中 进行 处 理 ， 其 代码 如 下 : 


SisShow = 'F'; 
让 (Gisset($_GET[f]) && $_GETT' ‘edit) || (isset($_POST[f]) && $ POST[?f] — ‘edit)) { 
让 Gisset($_ POST[f]) && $ POST[?] — ‘edit) { 
0 FILES[" 二 "J["name"]) && $_FILES["pubimg"]["name"] {= "") { 1/ 判断 是 否 重新 上 传 Logo 
upfiles/bookimg"; 


而 (is_dir($diD){ 
mkdir(Sdir); 


} 

Supfilename =$_FILES["pubimg"]["name"]; 

Sfilename = date("YmdHis") . mt_rand(1000, 9999) . substr($upfilename, strpos($upfilename, "."), strlen($upfilename) - 
strpos($upfilename, ".")); 


Saddress = $dir nj" . $filename; 
@move_uploaded file($_FILES["pubimg"]["tmp_name"], Saddress); /执行 上 伟 
Yelse{ 
“Sptmp = $adminDB->exeeuteSQL("select pubimg from tb_pub whereid- timts_POSTid]) .ws $connID); 
S$filename = $ptmp[0][pubimg']; 


if (! SadminDB->executeSQL("update tb_pub set pubname=". $_POST['pubname'] . ™, pubimg=" . $filename . "where id=" . 
$ POST[id] ."", SconnID)) { /更 改 出 版 社 类 别 信息 
echo "<script>alert(' 出 版 社 类 别 更 改 失败 ! ):</script>"; 
jelse{ 
echo "<script>alert(' 出 版 社 类 别 更 改 成 功 ! );</script>"; 
} 


} 

让 (isset($ GETTidTD){ 
$id=$ GET[id]; 

} else{ 

$id=$_POST['id']: 


S$isShow = '"T'; 


Spub = $adminDB->executeSQL("sclect id, pubname, pubimg from tb_pub where id=" . $id . w", $connID); 
$smarty->assign('pub’, $pub); 


} 
上 述 代 码 首 先 判断 是 否 又 重新 上 传 出 版 社 Logo， 如 果 是 则 重新 上 传 ， 反 之 则 不 进行 任何 操作 ， 然 后 使 用 数 
据 库 管理 类 的 executeSQL0 方 法 执行 update 语句 更 改 出 版 社 类 别 信息 。 
(3) 如 果 单 击 出 版 社 类 别 列表 “删除 ”按钮 并 确认 删除 后 ， 将 通过 如 下 代码 删除 指定 的 出 版 社 类 别 信息 ， 

if(isset($ GET[fTD &&s GETIf1='del) { 

if(! $adminDB->executeSQL("delete from tb_pub where id=" . $_GET['id] . "", $connID)) { 

echo "<script>alert( 出 版 社 类 别 删 除 失败 ! :</script>"; 
} 


} 
图 秘笈 心 法 


心 法 领悟 619: 删除 存储 在 数据 表 中 的 出 版 社 类 别 信息 。 
这 样 删除 的 只 是 存储 在 数据 表 中 的 出 版 社 类 别 信息 ， 并 不 能 将 存储 在 服务 器 文件 夹 下 的 图 片 删除 。 如 果 要 
删除 存储 在 服务 器 文件 夹 下 的 图 片 ， 必 须 在 服务 器 文件 夹 下 手动 删除 。 


15.11 图 书 管 


图 书 管理 模块 主要 用 于 对 图 书信 息 和 图 书 试 读 信息 进行 管理 ， 本 节 将 以 实例 的 形式 对 明日 科技 图 书 网 的 图 
书信 息 管理 模块 进行 讲解 。 
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实例 620 


力 实例 说 明 


明日 科技 图 书 网 的 定位 为 图 书 产品 的 展示 和 和 销售， 所 以 图 书信 息 管理 模块 非常 关键 ， 该 项 目的 图 书信 息 管 
理 模块 主要 包括 对 图 书信 息 的 添加 、 更 改 、 删 除 和 查询 等 操作 。 在 图 书信 息 添加 页 面 中 ， 添 加 的 内 容 包括 图 书 
的 名 称 、 类 别 、 页 数 、 字 数 、 作 者 、ISBN 号 和 价格 等 ， 其 运行 效果 如 图 15.52 所 示 。 
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图 15.52 图 书信 息 添加 


力 关键 技术 


在 图 书信 息 管理 中 ， 非 常 关键 的 一 点 是 明确 数据 表 的 各 个 字段 代表 的 含义 。 在 明日 科技 图 书 网 的 前 台中 ， 
在 对 图 书信 息 进行 分 类 时 ， 依 据 的 就 是 图 书信 息 表 中 某 个 字段 的 值 ， 例如， 判断 图 书 是 否 为 新 书 、 是 否 特价 等 。 
所 以 必须 对 图 书信 息 表 中 各 个 字段 了 如 指 掌 才能 更 好 地 完成 判断 操作 。tb_bookinfo 图 书信 息 表 的 说 明 如 表 15.2 
所 示 。 


表 15.2 tb_bookinfo 图 书信 息 表 


自动 增长 
bookname varchar 大 类 名 称 
smalltypeid datetime 添加 时 间 
oldprice float 书 原价 
newprice float 本 站 价格 
bookimg varchar 图 书 封面 图 片 名 称 
isnew bool 是 否 新 书 
addtime datetime 添加 时 间 
about text 图 书 介绍 
issepprice bool 是 否 特价 图 书 
browsertime 浏览 次 数 
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续 表 
字段 名 称 说 了 明 
ismrbooktj 是 否 *# 科 技 创作 
pubid 出 版 社 
writer 作者 
pubtime 出 版 时 间 
ishave 是 否 有 货 
bookcc 图 书 层次 标识 
Page 图 书页 码 
isbn 图 书 ISBN 号 
zs 图 书 字数 
bc 图 书 版 权 
directory 图 书目 录 
bookids 关联 图 书 ID 所 组 成 的 字符 串 
ishotsell 是 否 热卖 图 书 
isterm 是 否 期 书 


图 设计 过 程 


(1) 管理 员 首先 在 图 15.52 所 示 的 页 面 中 录入 图 书信 息 ， 然 后 单 击 “ 添 加 ”按钮 ， 则 图 书信 息 将 被 提交 到 


admin-book.php 文件 中 并 进行 保存 ， 其 代码 如 下 : 


让 (isset($_ POST[bookname]) && $_POST[bookname] !=" && $_POST['change] — F) { 
if(! $adminDB->executeSQL("select id, bookname from tb_bookinfo where bookname=" . trim($_POST[bookname"]) . "". $connID)) { 
1/ 判断 图 书信 息 是 否 已 经 被 添加 
if (isset($_FILES["bookimg"]["name"]) && $_FILES["bookimg"]["name"] = "") { 
files/bookimg"; 
让 (lis_dir(SdiD){ 
mkdir(Sdin; 
} 
Supfilename =$_FILES["bookimg"]["name"]: 
Sfilename = date("YmdHis") . mt_rand(1000, 9999) . substr($upfilename. strpos($upfilename, "."), strlen($upfilename) - 


strpos($upfilename, ". // 设 置 图 书 封面 名 称 
Saddress = $dir . "/". $filename; 
@move_uploaded file($_FILES["bookimg"]["tmp_name"]. $address); /上 传 图 书 封面 
jelse{ 
Sfilename =" 


S$pubtime = $_POST[pyear] . ~ .$_POST[pmonth] . '-00'; 

让 (! $adminDB->executeSQL("insert into tb bookinfo(bookname, smalltypeid, pubid, page, zs, isbn, be, writer, pubtime, oldprice, newprice, 
bookee, boakids bookimg, directory, about, isnew, issepprice, ishotsell, isterm ‘ismrbookt] ishave, addtime, browsertime) value 
trim($_POST[bookname]) . ", "trim($_POSTP'smalltypet i mm .trim(S_ POST[page]) . ", " . trim($_POST['zs"]) . 

". trim($_POST[isbn" time .wm .trim($_ POST[oldprice]) . ™, " 
trim($_POST[newprice Sfilename . ", ". trim($_POS "directory']) . 
trim($_POST['about]) . ™, 3 trim($_POST[ishotsell]) .wm , trim($_POST'isterm']) . 
™,". trim($_POST['ismrbooktj]) . ", " .trim($ POST[ishave]) . ™. " . date('Y-m-d H:i: .0)", SconnID)) { // 保 存 图 书信 息 

echo "<script>alert("| 图 书 添加 失败 1 ;</script>": 
} else{ 
echo "<script>alert( 图 书 添加 成 功 ! ):</script>": 


} 
}else{ 

echo "<script>alert(' 该 图 书 已 经 添加 ! ;</script>"; 
} 


} 
SisEdit = 下: 
让 (isset($_GET[f]) && $_GET[?] — ‘edit ||isset($_POST['change']) && S_ POST[change] 一 T){ 
if(isset($ POST['changeT) &&S POSTI'change|— T) { 
Ee FILES["bookimg"]["name"]) && $_FILES["bookimg"]["name"] (="") { 
="/upfiles/bookimg": 
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(Lis dir(Sdin) { 
mkdir($dir); 


和 
Supfilename = $_FILES["bookimg"]["aame"]: 
Sfilename = date("YmdHis") . mt_rand(1000, 9999) . substr($upfilename, strpos($upfilename. "."), strlen($upfilename) - 


addicss = Sai Sl 
; J uploadd filetS FTLES["bookimg"]["tmp name"], Saddress); 
clse 
S$tmpbook = $adminDB->execute SQL("sclect bookimg from tb_bookinfo where id=" . $ POST[id] . "", $connID): 
; S$filename = $tmpbook[O][bookimg']: 
Spubtime =$_POST['pyear] .  . $_POST[pmonth'] . -00'; 
.省略 用 户 设置 提交 内 容 的 代码 ， 请 参见 本 书 光盘 中 源码 
¥f(! SadminDB->exceuteSQL ("update tb_bookinfo set bookname = .trim($_POST[bookname']) . ", smalltypeid=" . 
"pubid=" . trim($_POST['pubid']) . ", page=" . im($_POST['page) . ", 25=" .trim($_POST[zsD) .", isbo=". 
trim($_POSTisbn']) . ", be=" ,trim 人 POST['beD) . ", writer=". trim($_POST[ wwriter)) . ", pubtime=", Spubtime , ", oldprice= 
tin($_POST[oldpriee] . ", newprice=" ,trim($_POST['newprice]) . ", bookee=" . tim(S_POSTIbookec]) . ", bookid ”trim oe 


", bookimg=" . $filename ,ws directory=" . trim($ POSTh directory']) . ", about=" . trim($ POSTTabout]) . ", isnew=" . Sisnew , ", issepprice™ 
Sissepprice . ", ishotsell=" . Sishotsell . ", isterm=". Sisterm . " ,ismrbooktj=". Sismrbooktj . " ,ishave=—". $ishave . " where id=" .$ POST[id] .mw 
SconnID)) { // 更 改 图 书信 息 


echo "<script>alert( 图 书信 息 更 改 失败 ! ');</script>"; 
}else{ 
echo "<script>alert( 图 书信 息 更 改 成 功 ! '):</script>"; 


} 
证 (isset($_ POST[id]){ 
$id=$ POSTTid1; 
j else{ 
$id=$_GET[id]: 
; 
SisEdit = T'; 
Sbook = SadminDB->executeSQL("select id bookname, smalltypeid pubid, Page, zs, isbn, be, writer, pubtime, oldprice, newprice bookee, behits 
bookimg, directory, about, isnew, issepprice. ishotsell, isterm ,ismrbookt] ishave, addtime. browsertime from tb_bookinfo where id=" . $id . " 
$connID): // 查 询 图 书信 息 


$smarty->assign(book', $book); 
ee >assign( pyear, substr($book[O]['pubtime'], 0, 4)): 
Ssmarty->assign('pmonth' substr(Sbook[0][pubtime], 5. 2)); 
在 上 述 代 码 中 ， 定 义 图 书信 息 添加 和 更 新 两 种 操作 。 首 先 判断 5_POST['change'"] 数 组 元 素 的 值 ， 如 果 该 值 为 
F， 则 进行 添加 操作 ， 通 过 数据 库 管理 类 的 executeSQL0 方 法 执行 insert 语句 将 图 书信 息 保存 到 数据 库 中 ， 同 时 
使 用 函数 move_uploaded file0 将 图 书 封面 上 传 到 服务 器 中 ; 如 果 $_POST['change"] 的 值 为 T， 则 执行 图 书信 息 的 
更 改 操作 , 在 更 改 图 书信 息 时 , 首先 判断 是 否 重新 选择 图 书 封面 , 如 果 是 , 则 重新 上 传 图 书 封面 , 然后 执行 update 
语句 对 图 书信 息 进 行 更 新 。 
(2) 图 书信 息 列表 主要 对 图 书 名 称 、 出 版 社 、 作 者 和 价格 等 进行 分 页 显示 ， 其 运行 效果 如 图 15.53 所 示 。 
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图 15.53 图 书信 息 列表 


通过 图 书信 息 列表 页 可 以 实现 对 图 书信 息 的 更 改 和 删除 操作 ， 在 讲解 图 书 添加 操作 中 已 经 介绍 了 图 书信 息 
更 改 的 实现 方法 ， 这 里 不 再 资 述 。 当 单 击 图 书信 息 列表 中 的 删除 按钮 时 ， 首 先 弹出 提示 对 话 框 提示 用 户 是 否 确 


认 删 除 ， 如 果 是 ， 则 通过 如 下 代码 执行 对 图 书信 息 的 删除 操作 : 
让 (isset($_GET[f]) && $_GET[?] —'del) { 
if(! $adminDB->executeSQL("delete from tb_bookinfo where id=" .$_GET[id] .™", $connID)) { 
echo "<script>alert( 图 书信 息 删除 失败 1! ):</script>"; 1/ 执行 删除 操作 
} 
} 
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(3) 与 其 他 管理 模块 相 比 ， 图 书信 息 量 较 大 ， 为 方便 对 图 书信 息 进行 管理 ， 在 图 书信 息 管理 模块 中 增加 了 
图 书信 息 查询 功能 ， 其 运行 效 果 如 图 15.54 所 示 。 
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图 15.54 图书 信息 查询 
首先 在 文本 框 中 输入 要 查询 的 关键 字 ， 然 后 单 击 “ 查 询 ” 按 钮 ， 这 时 查询 表单 的 关键 字 将 被 提交 到 


admin-searchbook.php 文件 中 ， 在 该 文件 完成 对 图 书信 息 的 查询 操作 ， 并 且 将 查询 结果 赋 给 模板 变量 ， 在 模板 页 
admin-searchbook.phtml 中 输出 查询 结果 ， 其 代码 如 下 : 


SisFind = F'; 
让 (isset($_POST[bookname]) && $ POST[bookname] != "||isset($_GET[bookname]) &&S_GET[bookname]!="){ /判断 是 否 提交 了 表单 
if(isset($_POST['bookname'])) { // 获 取 要 查询 的 图 书 名 称 
$bookname = $_POST['bookname']; 


}else { 
S$bookname = $_GET[bockname]; 
} 
Sbooks = $adminDB->executeSQL("select tb bookinfo id ,tb bookinfo.oldprice, tb bookinfo.newprice, tb bookinfo.bookname, 
tb_bookinfo.writer, tb_pub.pubname from tb_bookinfo, tb_pub where tb_bookinfo.pubid = tb_pub.id and bookname like '%" . $bookname . "%' order 
by tb_bookinfo.addtime desc", $connID): /| 执行 模糊 查询 


} 
上 述 代码 首先 使 用 函数 isset0 判 断 $_POST['bookname'] 数 组 元 素 是 否 已 经 被 设置 ， 如 果 是 ， 则 使 用 数据 库 管 
理 类 的 executeSQL() 方 法 执行 查询 操作 。 


国 秘笈 心 法 
心 法 领悟 620， 通 过 like 关键 字 执行 模糊 查询 ， 查 询 图 书 的 名 称 。 


在 本 实例 的 图 书 查询 中 ， 应 用 like 关键 字 执行 多 表 模 糊 查询 ， 查 询 图 书 的 名 称 ， 并 且 将 查询 结果 返回 到 模 
板 变量 中 。 


力 实例 说 明 


为 了 让 读者 选择 一 本 真正 适合 自己 的 图 书 并 且 吸 引 更 多 
读者 购买 ， 在 制作 明日 科技 图 书 网 时 增加 了 图 书 试 读 模块 ， a 

这 样 读者 在 购买 图 书 前 就 可 以 大 概 了 解 所 购买 图 书 的 内 容 ， | 
非常 人 性 化 。 在 图 书 试 读 信息 添加 页 面 中 包括 图 书 类 别 下 拉 mm 
列表 杠 、 图 书 名 称 选择 下 拉 列表 框 和 试 读 文件 名 称 输入 文本 
框 ， 其 运行 效果 如 图 15.55 所 示 。 图 15.55 添加 图 书 试 读 信息 页 面 


图 关键 技术 


在 添加 图 书 试 读 信息 的 模板 页 admin-read.phtml 中 ,通过 Smarty 模板 中 的 {ldelim} {rdelim} 标 签 直 接 在 模板 
页 中 编写 JavaScript 脚本 ， 应 用 jQuery 技术 实现 下 拉 菜 单 的 三 级 联动 ， 其 关键 代码 如 下 : 


<script sre=" {util->baseUrl}/js/jquery.js"></script> 
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<script language="javascript" > 
S(document) ready( 
fanetion0 {1delim} 
S("#bigtypeid").change(functionO {1delim} 
S$.get("{util->baseUrl} /getstype php?stid="+$("#bigtypeid").val|, null, fanction(data) {1delim} 


S$("#smalltypeid").change(functionO {1delim} 
S$.get(" {util->baseUrl}/getbook.php?bid="+$("#smalltypeid").valO), null, function(data) {ldelim} 
S$("#bookid").emptyO; 
S$("#bookid").append(data); 
{rdelim}); 
{rdelim}); 
a {rdelim} 
</script> 


图 设计 过 程 
(1) 管理 员 在 模板 页 admin-read.phtml 中 输入 图 书 3 试 读 信息 ,将 form 表单 中 的 数据 提交 到 admin-read.php 
文件 中 进行 保存 。form 表单 的 内 容 如 下 : 


<form name="form_read" method="post" action=" {util->baseUrl}/admin-read.php" onsubmit="return chkInputRead(this)"> 
<div style="width:100%; textalign:left padding-top:5px; padding-left:50px"> 类 别 。 &nbsp:&nbsp:&nbsp:&nbsp:&nbsp:&nbsp: 
<select id="bigtypeid" name="bigtypeid"> 
<option value=" selected>- 请 选择 -</option> 
{html options options = $arrayBtypeOption} 
</select>&nbsp; 
<select name="smalltypeid" id="smalltypeid"> 
<option value=" selected>- 请 选择 -</option> 
</select> <br /><br /> 
图 书 名 称 : &nbsp;&nbsp; 
<select name="bookid" id="bookid"> 
<option value=" selected>- 请 选择 -</option> 
</select> <br /><br /> 
试 读 文件 名 : <input type="text" name="filename" size="30" class="input"/><br /><br /> 
<input type="submit" value=" 添 加 " />&nbsp:&nbsp:<input type="reset" value=" 重 置 " /> 


</div> 
</form> 
(2) 新 建 admin-read.php 文件 ， 保 存 表 单 中 提交 的 试 读 信息 数据 ， 其 代码 如 下 : 
Sbtypes = $adminDB->executeSQL("select id, typename from tb_bigtype order by addtime", $connID): // 查 询 图 书 大 类 
for ($i= 0: $i < count($btypes): $i++) { // 将 大 类 保存 到 数组 中 


SarrayBtypeOption[$btypes[Si]["id']] = $btypes[S$i][ typename']; 
S$smarty->assign('arrayBtypeOption', $arrayBtypeOption): 


if(isset($_POST['filename']) && $ POST[ilename] (=") { // 判 断 是 否 提交 了 表单 
if(! $adminDB->executeSQL("select id filename from tb_read where bookinfoid=" .$_ POST[bookid] . ™", $connID)) { 
// 判 断 该 书 的 试 读 信息 是 否 已 经 添加 


证 (! $adminDB->executeSQL("insert into tb read(bookinfoid. filename, addtime) values(" .$ POST'bookid"] .™, " .$ POST['filename'] . 
"date('Y-m-d H:i:s) . ")", $connID)) { 
echo "<scriipt>alert( 试 读 添加 失败 ! ");</seript>"; 
}else{ 
echo "<script>alert( 试 读 添加 成 功 ! );</script>": 


} 
a "<script>alert(' 已 经 为 该 图 书 添加 试 读 ! ):</script>"; 
} 
} 
(3) 试 读 信息 列表 页 主要 以 分 页 的 形式 显示 出 试 读 图 书 的 名 称 、 试 读 文件 名 和 添加 时 间 等 信息 ， 其 运行 效 
果 如 图 15.56 所 示 。 
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图 15.56 ”图 书 试 读 信息 列表 


单 击 试 读 信息 列表 的 编辑 按钮 将 出 现 试 读 信息 更 改 表 单 ， 在 该 表单 中 修改 试 读 图 书 的 内 容 ， 将 表单 数据 提 
交 到 admin-listread.php 页 面 中 进行 修改 ， 其 代码 如 下 : 
if (Gisset($_GET[?]) && $ GET[f] 一 edit) || (isset($_POST['?]) && $_POST[f] — 'edit)) { 1/ 判断 是 否 提交 了 表单 
让 (isset($_ POST[f]) && $_ POST[?] — ‘edit) { 

if(! SadminDB->executeSQL("update tb_read set bookinfoid=" . $_POST['bookid] . ". filename=" .$_ POST[filcname] ." where id=" . 

$_POST[id] ."", SconnID)) { 。 /执行 更 改 操作 
echo "<seript>alert( 试 读 更 改 失败 ! <lscripP>": 
else { 
echo "<script>alert(' 试 读 更 改 成 功 ! :</script>"; 
} 


} 

if(isset($_GET[idD) { 
$id=$ GETTid1: 

}else{ 

$id=$_POST[id]; 


SisShow = 'T'; 

Sread = $adminDB->executeSQL("sclect tb_read iid, tb_read filename, tb_bookinfo.bookname, tb_read.addtime from tb_read, tb_bookinfo where 
了 b_read.bookinfoid =tb_bookinfo.id and tb_read.id=". $id . "", SconnID); // 查 询 试 读 信息 

S$smarty->assign('read', Sread); 
} 


单 击 试 读 信息 的 删除 按钮 ， 会 弹出 是 否 确认 删除 的 对 话 框 ， 如 果 选 择 确认 删除 ， 则 执行 如 下 代码 实现 试 读 
信息 的 删除 : 


if(isset($_GET[?]) && $_GET[?] = 'del) { 
if(! $adminDB->executeSQL("delete from tb_read where id=" . $ GET['id'] . "", $connID)) { 
echo "<script>alert(' 试 读 删 除 失败 ! );</script>"; // 执 行 删除 试 读 操作 


} 
图 秘笈 心 法 


心 法 领悟 621: 分 页 功能 的 实现 。 
在 本 实例 中 ， 试 读 信息 的 分 页 输出 应 用 的 是 分 页 类 中 的 pageData0 方 法 ， 将 分 页 查询 结果 赋 给 模板 变量 ， 
在 模板 页 中 创建 分 页 超 链接 ， 完 成 试 读 信息 的 分 页 输出 。 


15.12 用 户 管 理 


用 户 管理 模块 实现 的 功能 包括 对 网 站 注册 用 户 的 管理 和 对 用 户 反馈 信息 的 管理 ， 本 节 将 讲解 这 两 个 功能 的 
实现 过 程 。 


Eeessea 
让 i | dy i 
图 实例 说 明 


在 用 户 信息 管理 模块 中 对 网 站 注册 用 户 进行 分 页 输出 ， 输 出 内 容 包 括 用 户 昵称 、 真 实 姓 名 、 性 别 和 联系 电 
话 等 ， 其 运行 效果 如 图 15.57 所 示 。 
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15.57 浏览 用 户 信息 


力 关键 技术 


在 用 户 信息 管理 模块 中 ， 应 用 ADODB 类 库 、Smarty 模板 技术 实现 信息 的 分 页 输出 和 信息 的 删除 操作 ， 其 
应 用 的 技术 已 经 在 前 面 的 章节 中 详细 地 讲解 过 ， 这 里 不 再 次 述 。 

本 章 实例 的 所 有 内 容 就 是 对 一 个 完整 项 目的 分 解 ,通过 这 个 完整 的 项 目 巩 固 前 面 章 节 中 讲解 的 技术 。 所 以 ， 
在 本 章 中 ， 很 多 实例 应 用 的 关键 技术 都 没有 进行 详细 讲解 。 


图 设计 过 程 
(1) 浏览 用 户 信 息 由 admin-listuserphp 和 admin-listuser.phtml 两 个 文件 组 成 。 在 admin-listuser.php 文件 中 ， 


首先 判断 指定 的 分 页 变量 是 否 存在 ， 然 后 根据 $ GET[] 获 取 的 变量 值 进行 判断 ， 执 行 用 户 信息 的 删除 操作 、 执 行 
数据 的 分 页 输出 或 者 执行 查看 指定 用 户 的 详细 信息 ， 最 后 指定 模板 页 ， 其 代码 如 下 : 


<php 


require_once ‘admin-header.php'; // 包 含 头 文件 

if(! isset($_GET['page']) | $_GET[page] —") { // 判 断 分 页 变量 是 否 存在 
Spage ="1'; 

}else{ 
Spage = $_GET['page']; 

} 

if(isset($_GET['?]) && $_GET[?] =—'del) { // 判 断 是 否 执行 删除 操作 


if(! $adminDB->executeSQL("delete from tb_user where id=" .$_GET[id] . "", $connID)) { 
echo "<seript>alert( 用 户 信息 删除 失败 ! </script>": 
} 
$sql = "select id, useme, truename, email, sex, tel qq. address, logintimes, regtime, lastlogintime, ip, yb, usertype from tb_user order by usertype desc, 


regtime dese"; /定义 SQL 语句 

Susers = $pageDB->pageData($sql. $connID, 20. Spage): /执行 分 页 查询 

Ssmarty->assign('users', $users); // 将 查询 结果 赋 给 模板 变量 

SisShow = F'; 

if (isset($_GET['?]) && $_GET[f] =— 'edit) { // 判 断 是 否 输出 指定 用 户 的 详细 信息 
Suser = $adminDB->executeSQL("select id, userne, truename, email, sex, tel, qq. address, logintimes, regtime, lastlogintime, ip, yb, usertype from 

tb_user where id=" . $_GET['id] . "", $connID); 1/ 执行 查询 指定 用 户 的 详细 信息 
S$smarty->assign('user, $user); 
SisShow = T'; 

} 

S$smarty->assign('isShow', $isShow): 

S$smarty->display(admin-listuserphtml)): /指定 模板 页 

require_once ‘admin-footer.php'; /包含 尾 文件 


(2) 新 建 admin-listuser.phtml 模板 页 。 首 先 通过 section 语句 循环 输出 用 户 信息 ， 并 且 创 建 查看 指定 用 户 详 
细 信 息 和 删除 指定 用 户 的 超 链接 。 然 后 定义 分 页 超 链接 ， 完 成 数据 的 分 页 输出 。 最 后 根据 模板 变量 的 值 ， 判 断 
是 否 输出 指定 用 户 的 详细 信息 。 


国 秘笈 心 法 
心 法 领悟 622， 盘点 本 实例 中 应 用 的 技术 。 


本 实例 应 用 的 技术 包括 ConnDB 类 连接 MySQL 数据 库 、AdminDB 类 操作 MySQL 数据 库 、SmartyConfig 
类 配置 Smarty 模板 引擎 、PageDB 类 实现 分 页 操作 及 Util 类 中 的 方法 对 输出 字符 串 进行 格式 化 。 
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实例 623 


力 实例 说 明 
用 户 反馈 管理 模块 输出 用 户 对 网 站 本 身 、 网 站 中 的 某 本 图 书 ， 或 者 其 他 方面 的 一 此 建议、 意见 等 ， 其 输出 


效果 如 图 15.58 所 示 。 


[3 


PN 000 


所 
EE 
三: 
EE 


其 3 条 二 KE 示 20 订 着 ! 页 其 1 页 。 首页 上 一 页 下 一 


图 15.58 ”浏览 用 户 反馈 信息 


图 关键 技术 


本 实例 实现 的 功能 与 实例 622 是 相同 的 ， 唯 一 的 不 同 之 处 是 本 实例 操作 的 是 tb_feedback 数据 表 ， 而 用 户 信 
息 管理 实例 操作 的 是 tb_user 表 。 
图 设计 过 程 

(1) 浏览 用 户 反 馈 信息 由 admin-listuserfeedback.php 和 admin-listuserfeedback.phtml 两 个 文件 组 成 。 在 


admin-listuserfeedback.php 文件 中 ， 首 先 判断 指定 的 分 页 变量 是 否 存在 ， 然 后 根据 $_GET[] 获 取 的 变量 值 进行 判 
断 ， 执 行 用 户 反馈 信息 的 删除 操作 、 数 据 的 分 页 输出 或 者 查看 指定 用 户 反 馈 的 详细 信息 ， 最 后 指定 模板 页 ， 其 


代码 如 下 : 
<?php 
require_once ‘admin-header.php'; /包含 头 文件 
证 (! ee GET['page']) || $_GET[page] —") { 1/ 判断 分 页 变量 是 否 存在 
Spage = "1'; 
clse{ 
Spage = $_GET[page']: 
if (isset($_GET[?)) && $_GET[?] —'del) { // 判 断 是 否 执行 删除 操作 
if(! $adminDB->executeSQL("delete from tb_feedback where id=" .$_GET[id] . "", $connID)) { 


echo "<script>alert( 用 户 反馈 信息 删除 失败 ! :</script>"; 
} 


} 
$sql ="select id, useme,title addtime from tb_feedback order by addtime desc"; 


Sfeedbacks = $pageDB->pageData($sql, $connID, 20. Spage): /| 执行 分 页 查询 

S$smarty->assign('feedbacks'. $feedbacks): 

SisShow = F'; 

ff(isset($_GET[?]) && $_GET[?] — // 判 断 是 否 执行 详细 信息 查询 操作 

i title, content addtime from tb_feedback where id=" .$_GET[id] . "", $connID): 

SisShow = T'; 
S$smarty->assign('userfeed', $userfeed): // 将 查询 结果 赋 给 模板 变量 

} 

Ssmarty->assign('isShow’, $isShow); 

S$smarty->display('admin-listuserfeedback.phtml): // 指 定 模板 页 

require_once ‘admin-footer.php'; // 包 含 尾 文件 


(2) 新 建 admin-listuserfeedback.phtml 模板 页 。 首 先 通 过 section 语句 循环 输出 用 户 反馈 信息 ， 并 且 创 建 查 
看 指定 用 户 反馈 的 详细 信息 和 删除 指定 用 户 的 超 链 接 。 然 后 定义 分 页 超 链接 ， 完 成 数据 的 分 页 输出 。 最 后 根据 
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模板 变量 的 值 ， 判 断 是 否 输出 指定 用 户 反馈 的 详细 信息 。 


心 法 领悟 623: 配置 文件 的 存储 位 置 。 
在 本 实例 中 ， 应 用 到 ConnDB 类 、AdminDB 类 、SmartyConfig 类 等 类 文件 ， 但 是 在 本 实例 中 的 动态 文件 中 
并 没有 看 到 这 些 类 的 实例 化 操作 ， 因 为 这 些 操作 都 存储 于 admin-header.php 文件 中 的 lzh.inc.php 内 。 


15.13 订单 管理 


通过 明日 科技 图 书 网 的 订单 管理 模块 ， 可 以 对 读者 的 订购 信息 进行 管理 ， 本 节 将 介绍 订单 信息 管理 模块 的 
实现 方法 。 


实例 说 明 


明日 科技 图 书 网 输出 的 订单 信息 主要 包括 订单 号 、 订 购 人 、 联 系 电话 、 订 购 图 书 所 要 支付 的 各 项 费用 以 及 
目前 的 支付 状态 等 ， 其 运行 效果 如 图 15.59 所 示 。 
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图 15.59 用 户 订单 列表 


力 关键 技术 


在 订单 信息 管理 中 ， 同 样 必须 明确 tb_order 数据 表 中 各 个 字段 代表 的 含义 ， 这 样 才能 更 好 地 完成 对 订单 的 
更 改 操作 。tb_order 订单 信息 表 的 说 明 如 表 15.3 所 示 。 


表 15.3 tb_order 订单 信息 表 


字段 名 称 数据 类 型 字段 大 小 是 否 主键 说 了 明 
id int 11 主键 自动 增长 
orderno varchar 大 类 名 称 
orderusernc varchar 订购 用 户 昵称 
username varchar 订购 人 姓名 
address varchar 订购 人 联系 地 址 
E24 varchar 订购 人 性 别 

yb varchar 订购 人 邮编 

tel varchar 订购 人 联系 电话 
tt varchar 发 票 抬头 

idstr Varchar 订购 图 书 ID 组 成 字符 串 
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续 表 
字段 名 称 说 了 明 
numstr 订购 图 书 数量 组 成 字符 串 
goodsprice 图 书 价格 
yjprice 邮寄 价格 
totalprice 总 价格 
Tectype 收 货 方式 
paytype 支付 方式 
addtime 订购 时 间 
istk 是 否 付 款 
is 也 是 否 发 货 
issh 是 否 收 货 
isqx 是 否 被 用 户 取消 订购 


图 设计 过 程 


用 户 订单 管理 首先 完成 用 户 订单 信息 的 分 页 输出 ， 然 后 执行 订单 支付 状态 的 更 改 、 订 单 信息 的 查看 和 删除 


等 操作 。 


(1) 在 admin-listorder.php 文件 中 ， 首 先 包含 头 文件 ， 根 据 传递 的 查询 字符 串 page 的 值 并 通过 数据 库 分 页 


类 的 pageData0 方 法 实现 订单 信息 的 分 页 输出 。 然 后 通过 数据 库 管 理 类 的 executeSQL( 方 法 ， 执 行 update 语句 
实现 订单 状态 的 更 改 。 最 后 通过 数据 库 管理 类 的 executeSQL( 方 法 执行 select 语句 ， 查 询 指 定 订单 的 详细 信息 ， 
并 且 将 查询 结果 在 模板 页 中 输出 。admin-listorder.php 文件 的 代码 如 下 : 
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<?php 

require_once ‘admin-header.php'; // 包 含 头 文件 

if(! isset($_GET['page']) | $_GET['page] —") { // 判 断 分 页 变量 的 什 
Spage ="1'; 

}else{ 
Spage =$_GET['page']: 


if(isset($_GET[f]) && $_GET[f] = 'del) { // 判 断 是 否 执 行 删除 操作 
证 (! $adminDB->executeSQL("delete from tb_order where id=" .$ GET[id] ."", $connID)) { 
echo "<seript>alert(' 订 单 信息 删除 失败 ! ");</seript>": 
1 


} 
if(isset($_GET[c]) && $_GET['e] =") { // 更 改 订单 状态 
Sc=$_GET[e]: 
if($c=—='isfk) { // 判 断 是 否 已 经 付款 
$adminDB->exeeuteSQL("update tb_order set isfk = !isfk where id=" .$_GET[id] . "", $connID); 
} elseif ($c 一 isfh) { // 判 断 是 否 已 经 发 货 
$adminDB->executeSQL("update tb_order set isth = !isfh where id=" .$_GET[id] . "". $connID); 
} elseif ($c 一 'issh) { // 判 断 是 否 已 经 收 货 


$adminDB->executeSQL("update tb_order set issh = lissh where id=" . $_GET['id] . "", SconnID); 
} 


} 
$sql = "select id orderno, username, tel, goodsprice, yiprice, totalprice. is 全, isfh, issh. isqx from tb order order by addtime desc"; 
// 定 义 SQL 语句 


Sorders = $pageDB->pageData($sql. $connID, 20. Spage): /| 执行 分 页 查询 

S$smarty->assign('orders', $orders): // 将 查询 结果 赋 给 模板 变量 

SisShow = F'; 

让 (isset($_GET[f]) && $_GET[?] —'edit) { // 判 断 是 否 执行 查看 订单 详细 信息 的 操作 


Sorder = $adminDB->executeSQL("select id ordemo. usemame, address, sex. yb, tcL idstr, numstr, rectype, paytype. goodsprice, yjprice, totalprice, 
addtime, isfk. isfh, issh from tb_order where id=" .$_GET[id] ."", $connID); 。 // 执 行 查询 

Sarraylds = explode((@'、 Sorder[O]['idste ]): 

SarrayNums = explode( @". Sorderfo][numstr]): 

SarrayCarlnfos = array(): 

StotalPrice = 0: 

for ($i= 0: $i< count(SarrayIds): $i ++) { 
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Sbookid = $arrayIds[$i]: 
f($bookid =") { 
StmpArray = array(): 
S$bookinfo = $adminDB->executeSQL("select id, bookname ,oldprice, newprice from tb_bookinfo where id=" . $bookid . ™", $connID); 
S$tmpArray[id] = $bookinfo[ol[sd]: 
StmpArray[bookname'] = $bookinfo[O]['bookname']; 
StmpAmayl'oldprice] = Sbookinfo[O][ oldprice ]: 


i Nt 1]; 
StmpArray['smaliTotalPrice'] = Sbookinfo[0][mewprice] * $arrayNums[$i]; 
StotalPrice += $tmpArray['smallTotalPrice: 
array_push($arrayCarInfos, $tmpArray): 
} 
} 


S$smarty->assign('arrayCarlInfos', $arrayCarInfos); /将 生成 的 订单 详细 信息 赋 给 模板 变量 
Ssmarty->assign('‘order.. Sorder): 
SisShow = T': 
} 
S$smarty->assign('isShow', $isShow); // 通 过 该 变量 值 判断 是 否 输出 订单 详细 信息 
Ssmarty->display(admin-listorderphtml): // 指 定 模板 页 
require_once ‘admin-footer.php'; // 包 含 尾 文件 


(2) 在 admin-listorder.phtml 模板 页 中 ， 首 先 通 过 section 语句 循环 输出 订单 信息 ， 创 建 复 选 框 更 改 用 户 订 
单 的 状态 ， 创 建 查 看 订单 详细 信息 和 删除 指定 订单 的 超 链接 。 然 后 创建 数据 分 页 超 链接 ， 完 成 订单 信息 的 分 页 
输出 。 最 后 输出 模板 变量 中 存储 的 指定 订单 的 详细 信息 。 其 关键 代码 如 下 : 

<div style="border-right:1px solid #006D84: {if $orders.data[oID].isqx—1}padding-top:4px{/if}"> 

{下 Sorders.data[oID].isqx 一 1}-- 已 取消 --{else} 付 款 : <input type="checkbox" name="isfk" {if $orders.data[oID]iisftk 一 1}checked{/if} 
onclick="window.location.href="admin-listorder.php?c=isfk&id={$orders.data[oID].id}"™ />&nbsp:&nbsp: 

发 货 ，<input type="checkbox" name="isfh" {if Sorders.data[oID]isth 一 1}checked{/if} 
onclick="window .location href='admin-listorder.php?c=isfh&id= {S$orders.data[oID].id} ">&nbsp;é&nbsp; 

收 货 : <input type="checkbox" name="issh" {if $orders.data[oID].issh 一 1}checked{/if} 
onclick="window location_ href-'admin-listorder php?c=issh&id= {$orders.data[oID].id}"> 

{二 

</div> 

<div style="width:9%; height:20px; float:left; padding-top:2px"> 

<a href=" {util->baseUrl}/admin-listorder.php?{f=edit&id={$orders.data[oID] idj"><img sre=" {util->baseUrl} /img/edit.gif" border="0"/></a>&nbsp; 
<a href="javascript:if(window.confirm(' 确 定 删除 ? ) 一 tmucjfldelim}window location href- futil->bascUrlj/admin-listorderphp?f-del&id= 
{Sorders.data[oID] .id}'; {rdelim} "><img sre=" {util->baseUrl}/img/del.gif" border="0"/></a> 

</div> 
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心 法 领悟 624: 通过 复 选 框 完成 订单 状态 的 更 改 。 

在 admin-listorder.phtml 模板 页 中 创建 复 选 框 ， 通 过 onclick 事件 调用 JavaScript 脚本 ,在 JavaScript 脚本 中 ， 
应 用 window 对 象 的 location 方法 调用 admin-listorder.php 文件 ， 并 传递 两 个 参数 c 和 id， 在 admin-listorder.php 
文件 中 完成 订单 状态 的 更 改 操作 。 


15.14 通用 信息 管理 


在 通用 信息 管理 模块 可 实现 对 新 闻 公 告 、 网 上 畅销 书 讯 和 明日 图 书 排行 管理 ， 本 节 将 讲解 其 功能 的 具体 实 
现 方法 。 


高 级 
趣味 指数 : 位 博 祖 家 | 


实例 625 


力 实例 说 明 
在 新 闻 公告 管理 模块 中 ， 可 实现 新 闻 公 告 的 添加 、 浏 览 、 更 新 和 删除 操作 。 其 中 在 添加 新 闻 公 告 功能 中 ， 


PHP 开发 实例 大 全 (基础 卷 ) 
通过 CKEditor 文本 编辑 器 编辑 公告 的 内 容 ， 其 运行 效果 如 图 15.60 所 示 。 


图 15.60 添加 新 闻 公 告 信息 


图 关键 技术 


在 本 实例 中 ， 关 键 是 如 何在 Smarty 模板 页 中 嵌入 CKEditor 文本 编辑 器 ， 其 应 用 的 是 Util 类 中 的 editor( 方 
法 。editor0 方 法 的 语法 如 下 : 


function editor ($name, $value, $width ='100%', Sheight = '200){ 
require_once ‘library/fckeditor/fckeditor.php'; 
SarrayIni = $this->arrayIni; 
$oFCKeditor = new FCKeditor($Sname); 
SoFCKeditor->BasePath = $arrayIni[ baseUrl"] . /library/fckeditor/’; 
SoFCKeditor->Width = $width; 
$oFCKeditor->Height = $height; 
S$oFCKeditor->ToolbarSet = 'Default: 
S$oFCKeditor->Value = $value:; 
$oFCKeditor->Create(); 


. 
在 lzh.inc.php 文件 中 ， 应 用 Smarty 模板 中 的 register_object0 方 法 注册 一 个 模板 对 象 ， 其 关键 代码 如 下 : 
Sutil =new Util0: 
ee Sutil, null, false); 
在 模板 页 中 通过 注册 的 模板 对 象 调用 Util 类 中 的 editor0 方 法 , 完成 Fckeditor 文本 编辑 器 的 嵌入 操作 , 其 关 
键 代码 如 下 : 
{if $isEdit=="F"} 
{util->editor pl ='content' p2 ="}<br /><br /> 
0 Pl ='content p2 =$info[0].content}<br /><br /> 
<input type="hidden" name="id" value=" {$info[0].id}" > 
{i 


图 设计 过 程 
(1) 新 闻 公 告 的 添加 由 admin-telLphp 和 admin-tell.phtml 两 个 文件 组 成 。 在 admin-tell.phtml 模板 页 中 创建 


form 表单 ， 载 入 CKEditor 文本 编辑 器 ， 将 新 闻 公告 提交 至 admin-tellphp 文件 ， 完 成 新 闻 公 告 的 添加 操作 。 在 
admin-tell.php 文件 中 ， 调 用 数据 库 管理 类 中 的 executeSQL( 方 法 完成 新 闻 公告 的 添加 、 更 新 和 查询 操作 ， 其 关 


键 代码 如 下 : 
<?php 
require_once ‘admin-header.php'; /包含 头 文件 
ifisset($_ POST[title]) && S$_ POST['title]'-"&&lisset(S_ POST[id]){ // 判 断 提 交 的 ID 和 标题 是 否 为 空 


这 !$adminDB->executeSQL("select id title from tb_tell where title= "trimn($_ POST['title])."". SconnID)){ 
这 !$adminDB->executeSQL("insert into tb_tell(title. content addtime) values(".trim(S_POST[Yitle])." 
mtrim($_POST[ content]).",".date('Y-m-d H:i:s).")", $connID){ 
echo "<scriipt>alert( 公 告 添加 失败 ! ;</script>"; 
yelse{ 
echo "<script>alert( 公 告 添加 成 功 ! ;</script>": 
}else { 
echo "<script>alert(' 该 公告 已 经 添加 ! ):</script>": 
} 


} 
SisEdit = F'; 
这 isset($_GET[T]) &é& S$ GET[T] 一 edit | isset($_POST['id)) && $_POST[id]!="){ /判断 是 否 执行 更 新 操作 
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ifisset($_ POST[id]) && $_POST[id]!="){ 
if(!$adminDB->executeSQL("update tb tcll set title=".$_POST['title].". content=".$_POST['content]." where id=".$_ POST[id]"" 
SconnID){ 
echo "<script>alert( 更 改 失败 ! ");</script>"; 
Jelse { 
echo "<script>alert( 更 改 成 功 ! ");</script>"; 


人 
SisEdit ="T'; 
iflisset($_POST[idD) { // 判 断 提 交 的 ID 值 是 否 为 空 
Sid=$_ POST[id]: 
jelsef 
Sid=$_GET[id]: 


} 
Sinfo = $adminDB->executeSQL("select id, title, content from tb_tell where id=".$id."™", SconnID); // 执 行 查 询 操作 
Ssmarty->assign('info', Sinfo); // 将 查询 结果 赋 给 模板 变量 
} 
S$smarty->assign("isEdit, $isEdit); 
S$smarty->display(‘admin-tell.phtml"): /指定 模板 页 
require_once 'admin-footer php': 
(2) 新 闻 公告 浏览 由 admin-listtelLphp 和 admin-listtell.phtml 两 个 文件 组 成 。 在 admin-listtell.php 文件 中 ， 


首先 定义 删除 指定 新 闻 公 告 的 方法 ， 然 后 执行 新 闻 公告 的 分 页 查询 ， 最 后 指定 模板 页 ， 其 关键 代码 如 下 : 

< 
人 ‘admin-header.php'; // 包 含 头 文件 
ifisset($_GET[f]) && $_GET[?] — "del){ 

if(!$adminDB->executeSQL("delete from tb_tell where id=".$_GET['id]."", $connID)){ 

echo "<script>alert( 公 告 删除 失败 ! ;</script>"; 

} 

} 


$sql = "sclect id, title, addtime from tb_tell order by addtime dese"; // 定 义 分 页 查询 的 SQL 语句 
Stells = $pageDB->pageData($sql, $connID, 20, Spage): // 执 行 分 页 查询 
Ssmarty->assign('tells', $tells); 

S$smarty->display('‘admin-listtell.phtml’): // 指 定 模 板 页 

require_once ‘admin-footer.php'; // 包 含 尾 文件 


在 admin-listtell.phtml 模板 文件 中 ， 通 过 section 语句 循环 输出 新 闻 公 告 信息 ， 并 且 创 建 编辑 和 删除 超 链接 ， 
最 后 编写 分 页 超 链接 ， 其 关键 代码 如 下 : 


<div style="width:10%: height:20px; float:left; padding-top:2px"> 
<a href=" {util->baseUrl} /admin-tell.php?f=edit&id={ S$tells.data[tID].id} "><img sre=" {util->baseUrl} /img/edit. gif" border="0"/></a>&nbsp; 
<a href="javascriptif(window.confirm(" 确 定 删除 ? ")==true) {ldelim}window.location-href="{util->baseUrl}/admin-listtell.php? 人 =del&id= 
{Stells.data[D].id}'; {rdelim} "><img sre=" {util->baseUrl}/img/del.gif' border="0"/></a> 

<ldiv> 
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心 法 领悟 625: 盘点 本 章 实例 。 
本 章 实例 均 提 取 自 明日 科技 网 上 书店 这 个 完整 项 目 ， 其 目的 是 让 读者 了 解 前 面 章节 中 介绍 的 技术 在 实际 项 
目 开发 中 的 应 用 ， 以 此 来 巩固 前 面 所 学 知识 ， 真 正 做 到 理论 与 实践 相 结 合 ， 学 以 致 用 。 
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